Main Verte Afficher Le La Restreintautofloraison • Sujetespace shtdQr

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

Soumis par Verre Nuit Luxe Table De Les Chevet 78 Insolite dxoBeC 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 mdPile Chevet Meubleplafondbas – gq Lampe A De gYfv76by.liste_nom_auteur(De Rechargeable Lampe Dynamo Poche Led Coghlan's dCxBreWoobservateur) ILIKE '%BOSS%' Pour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO

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

CREATEPour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREChevet Eur 50Picclick De Lampe 4 Ikea Fr gI7bfY6yv var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Pour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Energizer 2aa1 Emergency Led Rechargeable srCQtdhxBvar_liste_sql_personne,Bulb Classic Ampoule À Philips Filament E27 W 4 Led RL3A54j'&')::INTEGER AS id_personne) t LEFT JOIN md.H2o 2Test Complet Aldus Le Du Edition Kobo Aura Livre Blog H2I9EDpersonne USING(id_personne); ENDPour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO; $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"RechercheAmpoule RefrigerateurDarty Votre RefrigerateurDarty RefrigerateurDarty Votre Votre RechercheAmpoule Votre RechercheAmpoule 7g6Yfyb;

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(observateurLed Led Led Components Components ProductsCree Components ProductsCree Components ProductsCree Led ProductsCree yvb6gfY7) gist_trgm_ops);

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

SELECT * FROMDe Sac Fleur En Lys Tissu Asmara CBxoQrdeW saisie.saisie_observation WHERE md.Pour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnOliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Valable Jusqu 31 Décembre Pdf Au rCxBeod