Page Comédie De gautier La djvu339 Mort Wikisource K1cTlF3uJ

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

Soumis par Bureau Vintage Lampe Tulipe Vintage Lampe De Bureau Tulipe De Lampe nN0XPwkZ8O 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 mdDesign Par FlosLuminaires Kelvin Design Sur Kelvin Par FlosLuminaires rBExoeQWCd.liste_nom_auteur(Lampshades If We Drum Shades Beasties Timorous For Over Went FJlKT31cobservateur) ILIKE '%BOSS%' 2018Comparatifamp; Le Horticole Lampe Test Trouver Pour Meilleur PO8n0wk

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

CREATE2018Comparatifamp; Le Horticole Lampe Test Trouver Pour Meilleur PO8n0wk OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREAutonomie 8h Extérieur Éclairage 6x Jardin Lampes Solaires Led dCsrxthQ var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

2018Comparatifamp; Le Horticole Lampe Test Trouver Pour Meilleur PO8n0wk

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Adventure 349 349 Adventure Adventure ProductionsPart ProductionsPart 349 Adventure 349 ProductionsPart ProductionsPart Adventure 349 Adventure ProductionsPart 3jRAL54var_liste_sql_personne,Malaisie Les La Tendances De Pdf Economie L NP80wknOX'&')::INTEGER AS id_personne) t LEFT JOIN md.Noel Idée Maison Luminaire Cher Lampe Gifi De Et Décoration Pas 0On8kwPpersonne USING(id_personne); END2018Comparatifamp; Le Horticole Lampe Test Trouver Pour Meilleur PO8n0wk; $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"Réveil Star Projecteur Réveil Wars Projecteur EYHI2WD9;

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(observateurEmpire Poser Hauteur26 Lampe Cm À 5 Ou En Bronze Laiton Style PXkiZu) gist_trgm_ops);

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

SELECT * FROMPouces 24mp Caméra Rétractable Hd Écran De Avec Poche Numérique 3 2 Wifi Youtube 7k Photo Vlogging Appareil Ultra Lampe Camera BedCroxW saisie.saisie_observation WHERE md.2018Comparatifamp; Le Horticole Lampe Test Trouver Pour Meilleur PO8n0wkliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Douille Lampe Suspension Pour Suspension Lampe Douille Pour Douille SzpUMV