________________________________
De: Alvaro Herrera <alvhe...@alvh.no-ip.org>
Para: Gabriel Ferro <gabrielrfe...@yahoo.com.ar>
CC: pgsql-es-ayuda@postgresql.org
Enviado: martes 27 de enero de 2009, 12:35:40
Asunto: Re: [pgsql-es-ayuda] Usasando Tsearch en 8.3
Gabriel Ferro escribió:
> 1º problema: ahora lo quiero hacer con un trigger y encontre que se hace con
>
> CREATE TRIGGER triggerpersonas BEFORE INSERT OR UPDATE
> ON personas FOR EACH ROW EXECUTE PROCEDURE
> tsvector_update_trigger('vectornombre', 'pg_catalog.spanish', 'nombre');
>
> pero no encuentro como hacerlo para cuando tengo dos campos tsvector.
¿Dos triggers?
> 2º problema cuando hago
>
> SELECT nombre,vectornombre,ts_headline(nombre,q),
> ts_rank_cd(vectornombre,q)
> FROM personas,
> to_tsquery('FERRO&GABRIEL') AS q
> WHERE vectornombre @@ q ORDER BY ts_rank_cd(vectornombre,q) DESC;
>
> entre los primeros me
>
> "FERRER GABRIEL ALEJANDRO";"'ferr':1 'gabriel':2 'alejandr':3";"<b>FERRER</b>
> <b>GABRIEL</b> ALEJANDRO";0.1
> "FERRER GABRIELA SUSANA";"'ferr':1 'susan':3 'gabriel':2";"<b>FERRER</b>
> <b>GABRIELA</b> SUSANA";0.1
> "FERRADA GABRIELA ALEJANDR";"'ferr':1 'gabriel':2
> 'alejandr':3";"<b>FERRADA</b> <b>GABRIELA</b> ALEJANDR";0.1
> "FERRANDO GABRIELA MARISA";"'ferr':1 'maris':3 'gabriel':2";"<b>FERRANDO</b>
> <b>GABRIELA</b> MARISA";0.1
> "RIVERA FERRADA GABRIEL H";"'h':4 'ferr':2 'river':1 'gabriel':3";"RIVERA
> <b>FERRADA</b> <b>GABRIEL</b> H";0.1
> "FERRO GABRIELA";"'ferr':1 'gabriel':2";"<b>FERRO</b> <b>GABRIELA</b>";0.1
> "FERRE GABRIELA ANGELICA";"'ferr':1 'angel':3 'gabriel':2";"<b>FERRE</b>
> <b>GABRIELA</b> ANGELICA";0.1
> "FERRO GABRIELA ANDREA";"'ferr':1 'andre':3 'gabriel':2";"<b>FERRO</b>
> <b>GABRIELA</b> ANDREA";0.1
> "FERRO GABRIELA MARIA ESTH";"'esth':4 'ferr':1 'mari':3
> 'gabriel':2";"<b>FERRO</b> <b>GABRIELA</b> MARIA ESTH";0.1
> "FERRO GABRIEL RAMIRO";"'ferr':1 'ramir':3 'gabriel':2";"<b>FERRO</b>
> <b>GABRIEL</b> RAMIRO";0.1
> y otros tantos mas
Todos tienen el mismo rank 0.1 ... ¿quizás tu problema es la forma como
está definida la función ts_rank_cd? Si te fijas todos tienen "gabriel"
y "ferr" en el tsvector.
Creo haber resuelto el problema haciendo de la forma
SELECT clave,nombre,vectornombre
FROM personas,
to_tsquery('FERRO&GABRIEL') AS q
WHERE vectornombre @@ q and
('FERRO&GABRIEL':: tsquery @@ nombre::tsvector)
ORDER BY ts_rank_cd(vectornombre,q) DESC;
pufff.... quede mas loco de lo que estaba... espero que este todo bien... si es
asi mil gracias a todos, sino..... ayuda plis...
Saludos
Yahoo! Cocina
Recetas prácticas y comida saludable
http://ar.mujer.yahoo.com/cocina/