Ver Mensaje Individual
  #2 (permalink)  
Antiguo 02/02/2012, 11:42
Avatar de srsombrero
srsombrero
 
Fecha de Ingreso: marzo-2008
Mensajes: 128
Antigüedad: 16 años, 1 mes
Puntos: 0
Respuesta: Motor de busqueda PHP

Cita:
Iniciado por ljbautista Ver Mensaje
Bueno mi pregunta es simple, ya he hecho motores de búsqueda simples, donde dado un campo de texto busco las coincidencias en una columna de una tabla.

Pero voy a hacer una búsqueda para una tabla de curriculums y lo que quieren es una búsqueda pero con una descripción mas larga, ejemplo:
"Ingeniero tractores Puebla"

Y que busque todas las coincidencias pero en toda la tabla no solo en una columna.

A diferencia de la búsqueda simple que lo que te pongan en el campo lo buscas en una columna, aquí debe buscar en todas.

Es como una búsqueda tipo de google, y no tengo idea de como empezar para hacer una búsqueda optima y que no sea tan lenta en una tabla con muchos registros :S

Ojala alguien pueda ayudarme a orientarme o no se si ya haya motores hechos que simplifiquen este tipo de búsqueda.

De antemano gracias amigos ;)
Aqui va una ayudita, mirate bien el codigo:

Código PHP:
<?php

$str_sch 
'Ingeniero marcos galvan';
$str_sch strtolower($str_sch);
$palabras explode(' ',$str_sch);
$query 'SELECT * FROM tabla_busqueda WHERE ';
if (
count ($palabras) > 1)
{
    foreach (
$palabras as $k => $v)
    {
        if ((
count($palabras) - 1) == $k)
        {
            
$query .= "campo LIKE '%$v%';"
        }
        else
        {
            
$query .= "campo LIKE '%$v%' OR "
        }
       
    }
}
else
{
        
$query .= "campo LIKE '%$palabras[0]%';"//Una sola palabra clave
}
echo 
$query;
?>