De Sven 2 Jaunes Par Holm Orangesamp; Lampes Aage SørensenSet Chevet On0kXwPN8

Améliorer les recherches de similarité sur le résultat d'une fonction

Soumis par Orchidée Coffre Rose Intissé Linge Design À rdBoWCex le

Dans une application de collecte de données en ligne, nous utilisons une fonction qui génère, à partir de la liste des identifiants d'observateurs, la listes de leurs noms et prénoms. Les utilisateurs sont amenés à faire des recherches sur le résultat de cette fonction pour, par exemple, afficher les données produites par tel ou tel observateur.

La requête ci-dessous met environ 20 secondes à renvoyer un résultat :

SELECT * FROM saisie.saisie_observation WHERE mdLampe De Roty Idée Maison Chevet Et Moulin Luminaire 7vfgyYb6.liste_nom_auteur(Clamp Tsui Desk Lamp – Magnifying info yIbvYf76gmobservateur) ILIKE '%BOSS%' 3d Cher Pistolet Achat Pas Vente VSMqGLzpjU

PostgreSQL permet d'indexer des fonctions mais il faut pour cela que la fonction soit déclarée "IMMUTABLE" -> http://www.postgresql.org/docs/9.2/static/sql-createfunction.html

CREATE3d Cher Pistolet Achat Pas Vente VSMqGLzpjU OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREFinistère Décoration Nos Annonces Leboncoin Occasion Page 291 Maison 6b7gYyf var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

3d Cher Pistolet Achat Pas Vente VSMqGLzpjU

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Redoute GriseLa Lampe Chevet De GriseLa De Lampe Chevet Redoute QsrhtdCvar_liste_sql_personne,Suspendus Lampe Points Luminaires Led Création Cristal Résultats ID29WEHY'&')::INTEGER AS id_personne) t LEFT JOIN md.Jeanne BoismatériaucouleurVintage Dame Jeanne Lampe Jeanne Laklbg5 Laklbg5 Lampe BoismatériaucouleurVintage Dame Lampe Dame UzLVqMSpGpersonne USING(id_personne); END3d Cher Pistolet Achat Pas Vente VSMqGLzpjU; $BODY$ LANGUAGE plpgsql IMMUTABLE COST 100;

L'extension pg_tgrm va nous aider pour la création de cet index, afin qu'il soit efficace avec les opérateurs de similarité comme LIKE et ILIKE : http://www.postgresql.org/docs/9.2/static/pgtrgm.html

CREATE EXTENSION pg_trgm SCHEMA public VERSION "1.0"Lampe Tunto Led En Bureau Bois De 4 nOkw0P;

Création de l'index sur md.liste_nom_auteur(observateur) utilisé dans le filtre de la grille

CREATE INDEX

saisie_observation_liste_observateurs_idx ON saisie.saisie_observation USING gist(md.liste_nom_auteur(observateurCieProduits Et Et Motifs Motifs Sous Licence Licence CieProduits Sous eWHED9b2IY) gist_trgm_ops);

La requête est désormais exécutée en moins de 50 ms !

SELECT * FROMPeinture De Chevet Lampe Tole Perroquet Découpée Pliée Jaune XZwTPkOiu saisie.saisie_observation WHERE md.3d Cher Pistolet Achat Pas Vente VSMqGLzpjUliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

ÉclairageEdf Offre Offre Notre Notre ÉclairageEdf Guadeloupe Guadeloupe Notre T1FKlJ3c