Foros del Web » Programando para Internet » PHP »

Búsquedas demasiado estrictas

Estas en el tema de Búsquedas demasiado estrictas en el foro de PHP en Foros del Web. El tema es que tengo un buscador que me hace búsquedaas muy estrictas. Es decir, si lo introducido en la base de datos es: a ...
  #1 (permalink)  
Antiguo 19/09/2006, 01:53
 
Fecha de Ingreso: marzo-2005
Mensajes: 33
Antigüedad: 19 años, 1 mes
Puntos: 0
Pregunta Búsquedas demasiado estrictas

El tema es que tengo un buscador que me hace búsquedaas muy estrictas. Es decir, si lo introducido en la base de datos es:
a - b
y yo busco
a b
no me lo encuentra.
El código que uso es el siguiente:
Código PHP:
if(isset($_POST['enviar'])) {



$query "SELECT * from $bd_tabla WHERE {$_POST['campo']} LIKE '%{$_POST['palabra']}%'";

$result mysql_query($query,$link);



$found false;

while (
$row mysql_fetch_array($result)) {

$found true;

echo 
"<p>";

foreach(
$row as $nombre_campo => $valor_campo) {




if(
is_int($nombre_campo)) {

continue;
}

echo 
"<b>".$nombre_campo."</b> : ".$valor_campo."<br>";
}

echo 
"</p>";

}

if(!
$found) {

echo 
"Pos de eso no tenemos";

}


¿Cómo soluciono esto?
Gracias
  #2 (permalink)  
Antiguo 19/09/2006, 02:34
Avatar de g05l21  
Fecha de Ingreso: mayo-2006
Mensajes: 76
Antigüedad: 17 años, 11 meses
Puntos: 1
Prueba a separar las palabras por los espacios y después hacer la consulta para la concatenación con sus respectivos '%'.

Si en la variable tienes 'a b' y lo separas por espacios tendrías un array con [0]=a, [1]=b, luego los puedes probar a encatenar (no lo he probado) con %a% %b% o mejor separarlo con dos clausulas where campo Like %[1]% and campo like %[2]% and...

No lo he probado, pero prueba por ahí.

Un saludo.
__________________
.-. GeL/T0 .-. Quieres saber mas de mi? lee mi blog: http://g05l21.net
  #3 (permalink)  
Antiguo 19/09/2006, 07:13
 
Fecha de Ingreso: marzo-2005
Mensajes: 33
Antigüedad: 19 años, 1 mes
Puntos: 0
algo mas claro por favor???
  #4 (permalink)  
Antiguo 27/09/2006, 01:44
Avatar de g05l21  
Fecha de Ingreso: mayo-2006
Mensajes: 76
Antigüedad: 17 años, 11 meses
Puntos: 1
A ver, lo único que tienes que hacer es una consulta por palabras sueltas, no vale que pongas %a b% porque esto busca las palabras que tienen algo, luego va 'a b' y luego cualquier cosa.

Lo que deberías buscar es algo del estilo "que el campo tenga %a% o que el campo tenga %b% o que el campo..." así para cada palabra.

La forma de hacerlo, separa las palabras por espacios (split) y luego para cada palabra pon un "OR campo like %palabra% "

Algo más claro así??
Un saludo
__________________
.-. GeL/T0 .-. Quieres saber mas de mi? lee mi blog: http://g05l21.net
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 00:15.