Foros del Web » Programación para mayores de 30 ;) » Bases de Datos General » Mysql »

[SOLUCIONADO] consulta mysql

Estas en el tema de consulta mysql en el foro de Mysql en Foros del Web. @import url("http://static.forosdelweb.com/clientscript/vbulletin_css/geshi.css"); Código MySQL: Ver original WHERE `propiedad` . `ubicacion` LIKE ' % euro % ' ESCAPE '!' OR `propiedad` . `direccion` LIKE ' % ...
  #1 (permalink)  
Antiguo 22/12/2016, 15:58
 
Fecha de Ingreso: julio-2010
Mensajes: 11
Antigüedad: 6 años, 9 meses
Puntos: 0
consulta mysql

Código MySQL:
Ver original
  1. WHERE `propiedad`.`ubicacion` LIKE '%euro%' ESCAPE '!'
  2. OR `propiedad`.`direccion` LIKE '%euro%' ESCAPE '!'
  3. OR `propiedad`.`referencia` LIKE '%euro%' ESCAPE '!'
  4. OR `publicacion`.`nombre_publicacion` LIKE '%euro%' ESCAPE '!'
  5. AND `PRINCIPAL_IMG` = 1 AND `is_active` = 1 AND `desea_online` = 1
  6.  AND `tipo_publicacion` = '3' LIMIT 20


al parecer los or de los like me cancelan los ands de los demas campos, como hago para que me devuelva por ejemplo:

en donde `tipo_publicacion` = '3'

porque me devuelve todos los tipo_publicacion (1, 2, 3)


Última edición por gnzsoloyo; 23/12/2016 a las 08:25
  #2 (permalink)  
Antiguo 22/12/2016, 21:06
Avatar de Libras
Colaborador
 
Fecha de Ingreso: agosto-2006
Ubicación: En la hermosa perla de occidente
Mensajes: 6.951
Antigüedad: 10 años, 9 meses
Puntos: 701
Respuesta: consulta mysql

Presedencia de operadores, y recuerda que cuando un or se cumple, se cumple toda la condicion ;)

Código MySQL:
Ver original
  1. WHERE (`propiedad`.`ubicacion` LIKE '%euro%' ESCAPE '!' OR `propiedad`.`direccion` LIKE '%euro%' ESCAPE '!'
  2. OR `propiedad`.`referencia` LIKE '%euro%' ESCAPE '!' OR `publicacion`.`nombre_publicacion` LIKE '%euro%' ESCAPE '!')
  3. AND (`PRINCIPAL_IMG` = 1 AND `is_active` = 1 AND `desea_online` = 1 AND `tipo_publicacion` = '3') LIMIT 20
__________________
What does an execution plan say to t-sql query? Go f**k yourself, if you are not happy with me

Última edición por gnzsoloyo; 23/12/2016 a las 08:31
  #3 (permalink)  
Antiguo 23/12/2016, 08:31
Avatar de gnzsoloyo
Moderador criollo
 
Fecha de Ingreso: noviembre-2007
Ubicación: Actualmente en Buenos Aires (el enemigo ancestral)
Mensajes: 23.170
Antigüedad: 9 años, 5 meses
Puntos: 2624
Respuesta: consulta mysql

Es exactamente como te dice Libras: No es el LIKE sino la forma en que relacionas las condiciones con OR.

Para er detallado, en tu WHERE tienes estas condiciones:
Condición 1
Código SQL:
Ver original
  1. `propiedad`.`ubicacion` LIKE '%euro%' ESCAPE '!'

Condición 2
Código SQL:
Ver original
  1. `propiedad`.`direccion` LIKE '%euro%' ESCAPE '!'

Condición 3
Código SQL:
Ver original
  1. `propiedad`.`referencia` LIKE '%euro%' ESCAPE '!'

Condición 4
Código SQL:
Ver original
  1. `publicacion`.`nombre_publicacion` LIKE '%euro%' ESCAPE '!'
  2. AND `PRINCIPAL_IMG` = 1
  3. AND `is_active` = 1
  4. AND `desea_online` = 1
  5. AND `tipo_publicacion` = '3'

Son cuatro condiciones diferentes e INDEPENDIENTES, y va a devover todos los caos que cumplan CUALQUIERA de las cuatro...

La unica forma de hacer que se consideren como una única condicion es usando los paréntesis.

En esencia, es la aplicación de Lógica Proposicional.
__________________
¿A quién le enseñan sus aciertos?, si yo aprendo de mis errores constantemente...
"El problema es la interfase silla-teclado." (Gillermo Luque)
  #4 (permalink)  
Antiguo 23/12/2016, 12:32
 
Fecha de Ingreso: julio-2010
Mensajes: 11
Antigüedad: 6 años, 9 meses
Puntos: 0
Respuesta: consulta mysql

gnzsoloyo gracias, si agrupar por paréntesis es la solución, mil gracias



La zona horaria es GMT -6. Ahora son las 19:47.