Foros del Web » Programando para Internet » PHP »

Buscar en alguna parte de una cadena

Estas en el tema de Buscar en alguna parte de una cadena en el foro de PHP en Foros del Web. Hola, Estoy intentado hacer un script que dada una cadena busque en una base de datos coincidencias. Me explico: La cadena es : "hola quetal ...
  #1 (permalink)  
Antiguo 01/11/2004, 14:23
 
Fecha de Ingreso: febrero-2003
Mensajes: 54
Antigüedad: 14 años, 10 meses
Puntos: 0
Buscar en alguna parte de una cadena

Hola,

Estoy intentado hacer un script que dada una cadena busque en una base de datos coincidencias. Me explico:

La cadena es : "hola quetal como estás", y quiero que mire por "h", por "ho", por "hola quetal com" por "hola quetal como está" etc, es decir, que busque relaciones en tooodas las letras hasta que encuentre una coincidencia en la base de datos (MySQL por cierto)

Busco algo como el proceso "indexOf" en javascript.

Por ahora lo que tengo es:

Código PHP:
$query "select * from palabrasclave WHERE frase LIKE '%$txtintroducido%'";
$resp mysql_query($query);
while (
$datos mysql_fetch_array($resp)) {

          echo 
"

$datos[respuesta]

"
;

          
$mostrar--;



Pero esto solo funciona poniendo desde el principio ya la cadena exacta, es decir, con la palabra "deporte" si lo introducido es "me gusta el deporte" no da resultado y si es "deporte basquet" tampoco, es decir, tiene que ser la frase exacta y yo quiero lo contrario, que busque a ver si hay alguna coincidencia por en medio de la cadena.

Gracias a todos

Última edición por pau8000; 01/11/2004 a las 14:25
  #2 (permalink)  
Antiguo 01/11/2004, 14:49
 
Fecha de Ingreso: junio-2003
Ubicación: Valencia
Mensajes: 334
Antigüedad: 14 años, 5 meses
Puntos: 0
Supongo que primero tendras que meter todas las letras de la palabra/s buscadas en un array y despues hacer un bucle para que las vaya comparando con el texto donde quieres que lo busque.
__________________
http://reunga.com
Desarrollo de aplicaciones informáticas
  #3 (permalink)  
Antiguo 01/11/2004, 14:52
Avatar de xcorpion  
Fecha de Ingreso: octubre-2003
Ubicación: m é x i c o
Mensajes: 676
Antigüedad: 14 años, 2 meses
Puntos: 4
tal vez puede hacerce por palabras
$txtintroducido = trim($txtintroducido);
$cont = str_replace(" ","%' OR frase like '%",$txtintroducido);
$cont = eregi_replace("^(%')","",$cont);
$cont = eregi_replace("('%)$","",$cont);

$query = "select * from palabrasclave WHERE $cond";
$resp = mysql_query($query);
while ($datos = mysql_fetch_array($resp)) {

echo "

$datos[respuesta]

";

$mostrar--;


}

Última edición por xcorpion; 01/11/2004 a las 14:53
  #4 (permalink)  
Antiguo 02/11/2004, 09:22
 
Fecha de Ingreso: febrero-2003
Mensajes: 54
Antigüedad: 14 años, 10 meses
Puntos: 0
FUNCIONA He cambiado un par de cosas, va perfecto. No había pensado en eso.! Muchas gracias.
  #5 (permalink)  
Antiguo 02/11/2004, 11:23
Avatar de xcorpion  
Fecha de Ingreso: octubre-2003
Ubicación: m é x i c o
Mensajes: 676
Antigüedad: 14 años, 2 meses
Puntos: 4
por nada, que bueno que funciona, se me paso lo de los articulos, seria bueno que eliminaras los articulos como: el, la, los,etc. y tambien las palabras que sean muy comunes.
  #6 (permalink)  
Antiguo 02/11/2004, 13:23
Avatar de andinistas  
Fecha de Ingreso: julio-2003
Ubicación: Bogotá COL
Mensajes: 1.000
Antigüedad: 14 años, 4 meses
Puntos: 0
ok

No está demás leer este artículo en Mysql Hispano

http://www.mysql-hispano.org/page.php?id=15&pag=1

sobre las Búsquedas de texto completo
__________________
Un Saludo, Andinistas.
"Llegaron... Ellos tenían la biblia y nosotros la tierra... y nos dijieron: 'Cierren los ojos y recen.' Cerramos los ojos y cuando los abrimos,
ellos tenían la tierra y nosotros la biblia." Abadío Green.
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 02:56.