Foros del Web » Programando para Internet » PHP »

Buscador en PHP

Estas en el tema de Buscador en PHP en el foro de PHP en Foros del Web. Buenas. resulta que en una página que voy desarrollando tengo que hacer un buscador pero hay 9 opciones para buscar: código-marca-modelo-color-responsable-estado(es un select con las ...
  #1 (permalink)  
Antiguo 01/11/2011, 20:28
 
Fecha de Ingreso: enero-2009
Mensajes: 23
Antigüedad: 15 años, 2 meses
Puntos: 1
Buscador en PHP

Buenas.
resulta que en una página que voy desarrollando tengo que hacer un buscador pero hay 9 opciones para buscar:

código-marca-modelo-color-responsable-estado(es un select con las opciones:buen estado-defectuoso-inactivo-reparación) y departamento(select con opciones: taller-recepción)

ahora bien, el usuario me ha dicho que bien puede seleccionar una opción o dos o tres o todas !!! es decir, buscar según estos criterios:

solo por código
por código y marca
por código, marca y estado
por marca y departamento
y así puede hacer las combinaciones de búsqueda que desee.

lo que hago ahorita es crear un if para cada combinacion posible pero llevo 25 selecciones de búsqueda y no parece acabar, osea, pongo esto:

/// buscando por serial, código, marca, modelo, responsable y electrica-sin estado

if ((trim($_POST['bserial']) != "") and (trim($_POST['bcodigo']) != "") and (trim($_POST['bmarca']) != "") and (trim($_POST['bmodelo']) != "") and (trim($_POST['bresponsable']) != "") and (($_POST['bestado'])=="obsoleto") and (($_POST['bdepartamento'])=="electronica")){
$msg= "buscando por serial, codigoUCA, marca, modelo y electrica";
/// y aquí iría la sentencia SQL que me realizaría la búsqueda
}


de esos IF ya llevo 25 y quisiera saber si hay alguna forma de captar esos criterios de búsqueda pues la pagina me esta creciendo demasiado y de veras no creo que esa sea la manera optima de hacerlo .

Última edición por pabletoreto; 01/11/2011 a las 21:18
  #2 (permalink)  
Antiguo 02/11/2011, 04:55
 
Fecha de Ingreso: octubre-2011
Mensajes: 37
Antigüedad: 12 años, 6 meses
Puntos: 9
Respuesta: Buscador en PHP

podrias generar primero la cadena de consulta y luego consultar a la bd, algo asi:

Código PHP:
$consulta 'SELECT * FROM tabla WHERE ';

foreach(
$_POST as $key => $value)
{
    
$value trim($value);
    if(!empty(
$value))
        
$consulta .= $key '=' $value ' AND ';
}

/*
realizar la consulta
$result = mysql_query($consulta);
*/ 
lo he cascado aqui en un momento sin probarlo, incluso te sobraria un ' AND ' al final, pero pulirlo un poco mas ya seria trabajo tuyo, creo que te valdria

Etiquetas: sql, buscadores, usuarios
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 07:38.