Cita:
Iniciado por ljbautista
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;
?>