Foros del Web » Programando para Internet » PHP »

Termina Scripts de Busqueda

Estas en el tema de Termina Scripts de Busqueda en el foro de PHP en Foros del Web. Ante todo saludos a todos, en un pequeño problema con el siguiente scripts, todo funciona perfectamente con este buscador, cuando el usuario introduc una sola ...
  #1 (permalink)  
Antiguo 26/08/2004, 15:06
 
Fecha de Ingreso: agosto-2004
Ubicación: Caracas-Venezuela
Mensajes: 26
Antigüedad: 20 años, 2 meses
Puntos: 0
Termina Scripts de Busqueda

Ante todo saludos a todos, en un pequeño problema con el siguiente scripts, todo funciona perfectamente con este buscador, cuando el usuario introduc una sola palabra, pero el problema esta cuando se coloca varia palabra el buscador indica no tiene nada en la base de datos. Por ejemplo si quiero buscar maria soto me dice que no tiene nada,sabiendo que en la bd tiene maria de soto. Mi especialidad no es la programacion por eso le pido una ayuda aqui les mando donde creo yo que esta el problema.

$criterio = "";
if ($_GET["criterio"]!=""){
$txt_criterio = $_GET["criterio"];
$criterio = " WHERE busqueda LIKE '%" . $txt_criterio . "%'";}
$sql="SELECT * FROM producto.allista ".$criterio;
$res=mysql_query($sql);
$numeroRegistros=mysql_num_rows($res);
if($numeroRegistros<=0)
He leido mucho sobre explode,fulltext, pero todavia no se como hacer
Gracias desde Venezuela
  #2 (permalink)  
Antiguo 26/08/2004, 17:01
Avatar de jpinedo
Colaborador
 
Fecha de Ingreso: septiembre-2003
Ubicación: Lima, Perú
Mensajes: 3.120
Antigüedad: 21 años, 1 mes
Puntos: 41
Una forma muy sencilla sería, como bien dices, utilizar la función explode():
http://www.php.net/manual/es/function.explode.php

El objetivo es poder construir un sql algo así:
Código PHP:
$sql "SELECT * FROM producto.allista WHERE busqueda LIKE %p1% OR busqueda LIKE %p2% OR busqueda LIKE %p3%"
Te voy a poner un ejemplo de cómo conseguir esto:
Código PHP:
//Suponiendo que las palabras por buscar están separadas por un signo "+":

if(!empty($_GET['criterio'])){
   
//Construyes un array con todas las palabras:
   
$array_keywords explode("+"$_GET["criterio"]);

   
//Construyes el sql:
   
$sql "SELECT * FROM producto.allista WHERE";
   
//Agregas el contenido de la cláusula WHERE, recorriendo el array
   
foreach($array_keywords as $posicion=>$keyword){
      
//Si es la primera, no se agrega el "OR".
      
$sql .= ($posicion!=0)?' OR':'';
      
//Se agrega una condición.
      
$sql .= " busqueda LIKE '%".$keyword."%'";
   }
   
//el resto lo haces igual
   
$res=mysql_query($sql);
   
//etc, etc, etc


Saludos

Última edición por jpinedo; 26/08/2004 a las 17:08
  #3 (permalink)  
Antiguo 27/08/2004, 05:16
DracoTronick
Invitado
 
Mensajes: n/a
Puntos:
Jpinedo, y si las palabras estan separadas no por un signo + sino que se encuentran en distintos "texarea"? El ejemplo que diste vos (por lo que entendi) es para poner en un mismo "texarea" las palabras a buscar separadas por el +. Y si quiero tener distintos texarea para cada valor, ¿como abria que hacer?

Saludos y gracias!
  #4 (permalink)  
Antiguo 27/08/2004, 07:21
 
Fecha de Ingreso: agosto-2004
Ubicación: Caracas-Venezuela
Mensajes: 26
Antigüedad: 20 años, 2 meses
Puntos: 0
Muchas gracias JPINEDO
problema resuelto
Como dije a principio esta no es mi especialidad, pero algo se de 3d studio max, cualquier cosa que yo te pueda ayudar, cuenta conmigo...
  #5 (permalink)  
Antiguo 28/08/2004, 18:29
Avatar de jpinedo
Colaborador
 
Fecha de Ingreso: septiembre-2003
Ubicación: Lima, Perú
Mensajes: 3.120
Antigüedad: 21 años, 1 mes
Puntos: 41
Cita:
Iniciado por DracoTronick
Y si quiero tener distintos texarea para cada valor, ¿como abria que hacer?
Si tienes varios campos de texto, ya no necesitarás el explode(), porque las variables ya vendrán separadas... además entenderé que utilizarás el método POST y no el GET.
Una forma sencilla de hacerlo es poner a los campos de texto que utilizarás para generar la condición como un array:
Por ejemplo, para tres campos:
Código:
<form action="tu_script.php" method="POST">
<input type="text" name=criterio[]><br />
<input type="text" name=criterio[]><br />
<input type="text" name=criterio[]><br />
<input type="submit" value="enviar">
</form>
Y en el "tu_script.php" tendrás lo siguiente:(ojo, que he tomado como base el script de Hermit)
Código PHP:
if(!empty($_POST['criterio'])){
   
//Construyes el sql:
   
$sql "SELECT * FROM producto.allista WHERE";
   
//Agregas el contenido de la cláusula WHERE, recorriendo el array
   
foreach($_POST['criterio'] as $posicion=>$keyword){
      
//Si es la primera, no se agrega el "OR".
      
$sql .= ($posicion!=0)?' OR':'';
      
//Se agrega una condición.
      
$sql .= " busqueda LIKE '%".$keyword."%'";
   }
   
//el resto lo haces igual
   
$res=mysql_query($sql);
   
//etc, etc, etc


Saludos
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 21:45.