Foros del Web » Programando para Internet » PHP » Frameworks y PHP orientado a objetos »

Pdo select-where-like

Estas en el tema de Pdo select-where-like en el foro de Frameworks y PHP orientado a objetos en Foros del Web. Hola gente, estoy utilizando la Clase PDO y tengo problemas para hacer una consulta del tipo SELECT ... WHERE ... LIKE, bueno tengo el metodo ...
  #1 (permalink)  
Antiguo 24/05/2010, 20:24
 
Fecha de Ingreso: marzo-2009
Mensajes: 76
Antigüedad: 15 años, 1 mes
Puntos: 1
Pdo select-where-like

Hola gente, estoy utilizando la Clase PDO y tengo problemas para hacer una consulta del tipo SELECT ... WHERE ... LIKE, bueno tengo el metodo de una clase, ha dicho metodo se le pasa una variable por parametro que es el valor a buscar. Dicha variable es $valor.

Aclaracion: - La variable $valor la imprimo dentro del metodo asique esta llegando bien.
- Tambien he probado con y sin el metodo TRIM().


Lo que estoy haciendo:
He intentado:
Código PHP:
$sql "SELECT * FROM tabla WHERE Nombre LIKE '%?%'" ;
$q $db->prepare($sql);
$cadena=trim($valor);
$q->execute(array($cadena)); 
Tambien intente: con y sin TRIM
Código PHP:
$sql "SELECT * FROM tabla WHERE Nombre LIKE ?" ;
 
$q $db->prepare($sql);
$cadena="'%".trim($valor)."%'";
$q->execute(array($cadena)); 
Y cuando hago asi funciona:
Código PHP:
$sql "SELECT * FROM tabla WHERE Nombre LIKE ?" ;
 
$q $db->prepare($sql);
$cadena='%a%';
$q->execute(array($cadena)); 
Alguien me podria decir como hacer esta sonsulta, tambien he intentado de otros modos que he visto en varios sitios pero ninguna me funciona.

Desde ya muchas gracias.

NicoStone.
  #2 (permalink)  
Antiguo 24/05/2010, 21:13
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 11 meses
Puntos: 2135
Respuesta: Pdo select-where-like

Código PHP:
Ver original
  1. $sql = "SELECT * FROM tabla WHERE Nombre LIKE ?" ;
  2.  $q = $db->prepare($sql);
  3. $cadena='%'.trim($valor).'%';
  4. $q->execute(array($cadena));

Saludos.
  #3 (permalink)  
Antiguo 24/05/2010, 21:21
 
Fecha de Ingreso: marzo-2009
Mensajes: 76
Antigüedad: 15 años, 1 mes
Puntos: 1
Respuesta: Pdo select-where-like

Muchas Gracias GatorV!!!!! me estaba matando esta consulta.

Probada y funcionando!!!

Saludos y gracias de nuevo.

NicoStone.
  #4 (permalink)  
Antiguo 24/05/2010, 22:19
Avatar de abimaelrc
Colaborador
 
Fecha de Ingreso: mayo-2009
Ubicación: En el planeta de Puerto Rico
Mensajes: 14.734
Antigüedad: 14 años, 11 meses
Puntos: 1517
Respuesta: Pdo select-where-like

Pregunta ¿qué diferencia haría hacerlo de la segunda forma?
Código PHP:
Ver original
  1. //Primera forma
  2. $sql = "SELECT * FROM tabla WHERE Nombre LIKE ?" ;
  3. $q = $db->prepare($sql);
  4. $cadena='%'.trim($valor).'%';
  5. $q->execute(array($cadena));
  6.  
  7. //Segunda forma
  8. $sql = "SELECT * FROM tabla WHERE Nombre LIKE ?" ;
  9. $q = $db->prepare($sql);
  10. $q->bindValue(1, '%'.trim($valor).'%', PDO::PARAM_STR);
  11. $q->execute();
__________________
Verifica antes de preguntar.
Los verdaderos amigos se hieren con la verdad, para no perderlos con la mentira. - Eugenio Maria de Hostos

Última edición por abimaelrc; 24/05/2010 a las 22:26
  #5 (permalink)  
Antiguo 25/05/2010, 08:53
Avatar de GatorV
$this->role('moderador');
 
Fecha de Ingreso: mayo-2006
Ubicación: /home/ams/
Mensajes: 38.567
Antigüedad: 17 años, 11 meses
Puntos: 2135
Respuesta: Pdo select-where-like

Ninguna, es simplemente otra forma de hacerlo, el problema en su caso era como estaba escapando el parámetro.

Saludos.

Etiquetas: pdo
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 16:27.