Foros del Web » Programando para Internet » PHP »

[SOLUCIONADO] Busqueda en clase

Estas en el tema de Busqueda en clase en el foro de PHP en Foros del Web. Hola. Tengo esta clase que sirve para buscar por nombre, pero de manera parcial. Es decir debe utilizar un LIKE. Utilizo PHP/PDO. Cuál es la ...
  #1 (permalink)  
Antiguo 29/05/2017, 12:32
Avatar de bandolera  
Fecha de Ingreso: abril-2009
Mensajes: 577
Antigüedad: 10 años, 6 meses
Puntos: 6
Pregunta Busqueda en clase

Hola. Tengo esta clase que sirve para buscar por nombre, pero de manera parcial. Es decir debe utilizar un LIKE.
Utilizo PHP/PDO. Cuál es la sintaxis correcta?
Código PHP:
function buscar($criterio) {
    
$sql "SELECT cod, nom FROM tabla WHERE nom LIKE '%".:criterio."%'";
    
$data = new conexion();
    
$sth $data->prepare($sql);
    
$sth->bindParam(':criterio'$criterioPDO::PARAM_STR);
    
$sth->execute();


Gracias.
__________________
Todos somos iguales. NO! a la violencia de género.
  #2 (permalink)  
Antiguo 29/05/2017, 16:36
 
Fecha de Ingreso: noviembre-2014
Ubicación: peru-lima
Mensajes: 32
Antigüedad: 5 años
Puntos: 2
Respuesta: Busqueda en clase

like concat('%',:criterio,'%')

----------------------------------------------------------------
<?php

$DBH = new PDO("mysql:host=localhost;dbname=l", 'root', '');
// $DBH->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );

$STH = $DBH->prepare("SELECT nombre FROM usuarios WHERE nombre like concat('%',:letra,'%')");//***
//$STH = $DBH->prepare("SELECT nombre FROM usuarios WHERE nombre like ?"); //---
// $STH = $DBH->prepare("SELECT nombre FROM usuarios");
$letra = 'a';
$STH->bindParam(':letra', $letra, PDO::PARAM_STR);//***
//$STH->bindValue(1, "%$letra%", PDO::PARAM_STR);//---
// $STH->bindValue(1, "%$letra%");

$STH->execute();

// $STH->setFetchMode(PDO::FETCH_ASSOC);

while($row = $STH->fetch()) {
echo $row['nombre']."<br>";
}

// $DBH = null;

?>

Etiquetas: busqueda, clase, select, sql, tabla
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 12:40.