Foros del Web » Programando para Internet » PHP »

Problema con busqueda en mySQL

Estas en el tema de Problema con busqueda en mySQL en el foro de PHP en Foros del Web. Hola, a ver como os explico. Tengo un buscador que hace uso de 2 tablas. archivos y tags. La estructura de archivos es la siguiente: ...
  #1 (permalink)  
Antiguo 11/09/2008, 08:54
 
Fecha de Ingreso: diciembre-2002
Ubicación: bilbao
Mensajes: 345
Antigüedad: 21 años, 11 meses
Puntos: 3
Problema con busqueda en mySQL

Hola, a ver como os explico.

Tengo un buscador que hace uso de 2 tablas.

archivos y tags.

La estructura de archivos es la siguiente:

id,titulo,info,...

La de la tabla tags:

id,idfile,tag

idfile, coincidiría con la id de la tabla archivos, es decir, imaginaros que meto un registro en la base de
datos así.

"Tutorial php avanzado"

en la tabla archivos se guardaría:

id -> 10
titulo -> Tutorial php avanzado
info -> blablablalbalblabla

y en la tabla de tags:

id -> 1
idfile-> 10
tag -> Tutorial

----

id -> 2
idfile-> 10
tag -> php

---

id -> 3
idfile-> 10
tag -> avanzado

¿¿Hasta aquí me explico??

El caso es que al hacer la busqueda la hago así:

Código PHP:
$sacar =     "SELECT DISTINCT idfile\r\n" 
            
"FROM tags AS found_file\r\n" 
            
"WHERE (tag = '{$tags[0]}')\r\n";
    for (
$x 1$x count($tags); $x++) {
          
$sacar .= "AND (0 < (SELECT COUNT(id) FROM tags WHERE tag = '{$tags[$x]}' AND idfile = found_file.idfile))\r\n";
    }
        
$sacar .= "LIMIT $ini,$prints\r\n";
        
$sacar mysql_query($sacar);
        for (
$n=0;$n<10;$n++) 
        { 
        
$dataultimos mysql_fetch_assoc($sacar);
        
MAS CODIGO
        

La tabla tags tiene cerca de 3.000.000 registros y se queda bloqueada o tarda mucho en mostrar los registros.

Necesito ayuda, o para reestructurar las tablas o para cambiar el codigo que parece que hace que la tabla se me quede frita.

Muchas gracias
__________________
aste nagusia
  #2 (permalink)  
Antiguo 11/09/2008, 09:01
Avatar de the_web_saint  
Fecha de Ingreso: mayo-2008
Ubicación: localhost/tierra/america/panama
Mensajes: 1.229
Antigüedad: 16 años, 6 meses
Puntos: 43
Respuesta: Problema con busqueda en mySQL

Solo utilizas la tabla tag para esa busqueda??
Porque si es asi, no la necesitas, ya que podrias hacer una busqueda usando LIKE, con respecto al nombre del archivo!
__________________
..::The Saint::..
El pesimista se queja del viento; el optimista espera que cambie; el realista ajusta las velas.
  #3 (permalink)  
Antiguo 11/09/2008, 12:37
 
Fecha de Ingreso: diciembre-2002
Ubicación: bilbao
Mensajes: 345
Antigüedad: 21 años, 11 meses
Puntos: 3
Respuesta: Problema con busqueda en mySQL

help me please
__________________
aste nagusia
  #4 (permalink)  
Antiguo 11/09/2008, 12:49
Avatar de the_web_saint  
Fecha de Ingreso: mayo-2008
Ubicación: localhost/tierra/america/panama
Mensajes: 1.229
Antigüedad: 16 años, 6 meses
Puntos: 43
Respuesta: Problema con busqueda en mySQL

Como te he dicho te funcionaria, solo necesitas la tabla de archivos, y cuando ejecutas la busqueda haces un LIKe o MATCH con el nombre del archivo y la palabra a buscar.
__________________
..::The Saint::..
El pesimista se queja del viento; el optimista espera que cambie; el realista ajusta las velas.
  #5 (permalink)  
Antiguo 12/09/2008, 04:30
 
Fecha de Ingreso: diciembre-2002
Ubicación: bilbao
Mensajes: 345
Antigüedad: 21 años, 11 meses
Puntos: 3
Respuesta: Problema con busqueda en mySQL

mmm... voy a mirar pero date cuenta que si el titulo es

tutorial avanzado de PHP

si escribo tutorial PHP quiero que me aparezca.

Saludos
__________________
aste nagusia
  #6 (permalink)  
Antiguo 12/09/2008, 06:52
 
Fecha de Ingreso: diciembre-2002
Ubicación: bilbao
Mensajes: 345
Antigüedad: 21 años, 11 meses
Puntos: 3
Respuesta: Problema con busqueda en mySQL

a ver hay cosas que no entiendo, por ejemplo:

SELECT * FROM archivos WHERE MATCH (titulo, artist) AGAINST ('%Rosario%' IN BOOLEAN MODE) AND MATCH (titulo, artist) AGAINST ('%dudaria%' IN BOOLEAN MODE)

Hago eso y me muestra como 10 archivos diferentes que contienen esas 2 palabras en Titulo y artist, el problema es que el registro que me saca por ejemplo es asi:

Rosario No dudaria

hasta aquí todo bien, pero si le añado a la busqueda

AND MATCH (titulo, artist) AGAINST ('%No%' IN BOOLEAN MODE)

es decir:

SELECT * FROM archivos WHERE MATCH (titulo, artist) AGAINST ('%Rosario%' IN BOOLEAN MODE) AND MATCH (titulo, artist) AGAINST ('%dudaria%' IN BOOLEAN MODE) AND MATCH (titulo, artist) AGAINST ('%No%' IN BOOLEAN MODE)

me devuelve que no hay ningún registro. Esto no tiene sentido, no?
__________________
aste nagusia
  #7 (permalink)  
Antiguo 12/09/2008, 07:47
Avatar de the_web_saint  
Fecha de Ingreso: mayo-2008
Ubicación: localhost/tierra/america/panama
Mensajes: 1.229
Antigüedad: 16 años, 6 meses
Puntos: 43
Respuesta: Problema con busqueda en mySQL

Bueno, te doy una idea de como lo haria yop.
Primero haria un explode de las palabras a buscar, esto por medio del espacio en blanco, esto me dara un arreglo de las palabras a buscar, OK

Luego genero el where con los diversos tipos de busqueda, es decir con LIKE del titulo y la primera palabra, o(operador), LIKE de titulo y la segunda palabra, y asi sucesivamente hasta terminar el arreglo, esto me dara como resultado todas las opciones que tengan estas palabras en el titulo.

No c si hay una mejor forma, pero creo q es mejor que crear una tabla para eso amigo

Saludos
__________________
..::The Saint::..
El pesimista se queja del viento; el optimista espera que cambie; el realista ajusta las velas.
  #8 (permalink)  
Antiguo 15/09/2008, 06:06
 
Fecha de Ingreso: agosto-2008
Mensajes: 4
Antigüedad: 16 años, 2 meses
Puntos: 0
Respuesta: Problema con busqueda en mySQL

Mikeln85 te mande un mensaje privado referente a tu post sobre hispadb , porfavor contestamelo :S (el de por qué no me recomendabas usar Hispadb)
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 12:51.