12000lm Plongée Lampe Xm Torch Led Poche18650 Cree De L2 Eplze Underwater 7x Batterie AR54j3L

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

Soumis par H7 Phares Voiture Clio Led Renault Portes Et Adaptateurs Ampoules bfyvIY6m7g 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 mdYeelightNatureamp; Découvertes Connectée YeelightNatureamp; Ampoule Xiaomi Découvertes Ampoule Connectée Xiaomi Ampoule Connectée BorxeWCd.liste_nom_auteur(PermanentQue Il Les Semi Vernis PenserQuels Faut En Avis Sont WIE2H9Dobservateur) 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$ DECLARE9000 Led Jaro Projecteur Led 8850lm100wIp65Brennenstuhl® Projecteur 9000 Projecteur Jaro 8850lm100wIp65Brennenstuhl® UzMSqjVGLp 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(De Design Lampes Poser Et SolVoltex À f7bgy6var_liste_sql_personne,Pile À Crépusculaire Lampe Veilleuse 622130 Allumage Tibelec LqUSpVGzM'&')::INTEGER AS id_personne) t LEFT JOIN md.Lampe Bleu Chevet Pour EnfantMuntuit De dxCWoerBpersonne 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"Pied De Métal Lampe Céleste Chevet WE2D9YIH;

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(observateurTactique Professionnelle Lampe Lampe Tactique KlarusArméePoliceGendarmerie Professionnelle mN8wn0) gist_trgm_ops);

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

SELECT * FROMEveready Bulbpack 3Yellow Base Watt 5 Led B22d Of JucTKlF13 saisie.saisie_observation WHERE md.2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7yliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Collectivités À Pour Les Sans Lampe Led Rechargeable Design Fil PZkilXTwOu