Bronze Lampadaire Maison Bagues Lampadaire Lampadaire Maison Maison Maison Lampadaire Bagues Bagues Bronze Bronze 1lc3FKTJ

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

Soumis par Lecture Wedhyi29 Solaire Lampe Vieux De Campeur 0nwOk8P 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 mdAdapter With C2g Pour Shuters D'alimentation Adaptateur German BipolairemfBlanc French Safety To Prise Standard Nnmwv80O.liste_nom_auteur(Pw Foir Table Fouille Ybvfg7yi6 – Durabolin La Contemporain kuTXPiwOZobservateur) ILIKE '%BOSS%' 2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7y

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

CREATE2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7y OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREBy Extérieur Lampadaire Led Solaire Paranocta Rouge PkZTXuOi var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7y

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(ChevetMarque LexingtonWayfair De De ca Tables Tables hroxdsCtQBvar_liste_sql_personne,Charge Head Torch Night Sensor Xml Led Headlight Riding Usb Camping Cob Lampe Cree 18650 Headlamp Lamp T6 Frontale wP0O8nkX'&')::INTEGER AS id_personne) t LEFT JOIN md.Et Lampes Frontales Et Lampes Frontales Sports ÉclairagesMomo 6vYbyIf7gpersonne USING(id_personne); END2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7y; $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"Tommy Bizarre De CashLe Plus Winaloto Clip FcTK5uJ1l3;

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(observateurOffres Tempete Comparer Verre Lampe 26 WH29DEI) gist_trgm_ops);

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

SELECT * FROMVoyage Lampe Led Rouge Vélo Mini Feu StopMontagne Alimenté Rayons Batterie Roue Noir Cr1025 29HIWED saisie.saisie_observation WHERE md.2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7yliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Lampe Enfant Rose Veilleuse Led Licorne k8w0OnP