Foros del Web » Programando para Internet » PHP »

Varios like en una consulta

Estas en el tema de Varios like en una consulta en el foro de PHP en Foros del Web. hola a todos, tengo el ste codigo, el problema es que cuando utilizo solamente un LIKE me funciona, pero si utilizo dos o mas ya ...
  #1 (permalink)  
Antiguo 19/06/2011, 06:03
 
Fecha de Ingreso: junio-2011
Mensajes: 12
Antigüedad: 12 años, 11 meses
Puntos: 1
Varios like en una consulta

hola a todos, tengo el ste codigo, el problema es que cuando utilizo solamente un LIKE me funciona, pero si utilizo dos o mas ya no me funciona

prepare(

'SELECT users.id, users.nom, users.Prenom, users.etudes_finies, users.annee_enim, users.mail, users.groupe, userfiche.id, userfiche.lv1ce, userfiche.lv1cl, userfiche.lv1co, userfiche.lv1ex, userfiche.lv1ec, userfiche.lv2alce, userfiche.lv2alcl, userfiche.lv2alco, userfiche.lv2alex, userfiche.lv2alec, userfiche.lv2esce, userfiche.lv2escl, userfiche.lv2esco, userfiche.lv2esex, userfiche.lv2esec, userfiche.lv2frce, userfiche.lv2frcl, userfiche.lv2frco, userfiche.lv2frex, userfiche.lv2frec, userfiche.toeic, userfiche.concerneFle
FROM users
INNER JOIN userfiche ON users.id = userfiche.id
WHERE users.nom LIKE ? Xor users.Prenom LIKE ? Xor users.annee_enim = ? Xor users.groupe = ?');

$req->execute(array("$_POST[rnom]%"," $_POST[rprenom]%", $_POST['rannee_sortie'], $_POST['rgroupe']));
  #2 (permalink)  
Antiguo 19/06/2011, 11:00
Avatar de repara2  
Fecha de Ingreso: septiembre-2010
Ubicación: München
Mensajes: 2.445
Antigüedad: 13 años, 7 meses
Puntos: 331
Respuesta: Varios like en una consulta

Código SQL:
Ver original
  1. INNER JOIN userfiche ON users.id = userfiche.id
  2. WHERE users.nom LIKE ? XOR users.Prenom LIKE ? XOR users.annee_enim = ? XOR users.groupe = ?');

Hola lisdymari, supongo que esta sintaxis responde a la librería / framework que estás usando. Si trabajas con MySQL, la linea ... LIKE ? te dará un error de sintaxis. Creo que basta con poner algo como
Código MySQL:
Ver original
  1. INNER JOIN userfiche ON users.id = userfiche.id
  2. WHERE users.nom LIKE "?" Xor users.Prenom LIKE "?" Xor users.annee_enim = "?" Xor users.groupe = "?"'
No sé si te ayudo, salu2
__________________
Fere libenter homines, id quod volunt, credunt.
  #3 (permalink)  
Antiguo 19/06/2011, 11:20
 
Fecha de Ingreso: junio-2011
Mensajes: 12
Antigüedad: 12 años, 11 meses
Puntos: 1
Respuesta: Varios like en una consulta

mira, es q cuando utilizo un solo LIKE funciona, pero cuando utilizo el segundo no funciona el like y presenta datos que no corresponden
  #4 (permalink)  
Antiguo 19/06/2011, 12:02
Avatar de repara2  
Fecha de Ingreso: septiembre-2010
Ubicación: München
Mensajes: 2.445
Antigüedad: 13 años, 7 meses
Puntos: 331
Respuesta: Varios like en una consulta

Es imposible saber qué resultados tiene que arrojar la consulta sin tener las tablas y los datos. Puedes empezar por hacer un poco de debug, no utilices XOR, resuelve la consulta con OR y AND de manera mas simple a ver si funciona. Luego complica lo necesario pero comprueba siempre la sintaxis, y, eventualmente, comprueba manualmente si la condición que tú pides se esatá cumpliendo. La select ltal como la presentas es un poco compleja, salu2
__________________
Fere libenter homines, id quod volunt, credunt.

Etiquetas: Ninguno
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 06:39.