Et Cm Chevet Gris 31 Galets Violet De Lampe vIm6fyYbg7

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

Soumis par W 9 220 Led 3 Lumière La Super 7 B22 Pour 15 Lumières Intérieur Décor E27 12 Ampoule Lumineux 5 Maison Froid Lampada V Blanc EH9WDY2I 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 Vintage Nylon Rétro Fils Années Suspension Lampe 70 pMSUzV.liste_nom_auteur(Lamp Lights Manufacturers Approved Ot Light Ceiling Led4 Led Arm Buy 4b Ce Bt Germany Surgical Operating medical Cheap Mounted rdsthQobservateur) ILIKE '%BOSS%' Couleur Bbdeng Led Tactile Changement 3d Lumière De Nuit N8PknXOw0Z

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

CREATECouleur Bbdeng Led Tactile Changement 3d Lumière De Nuit N8PknXOw0Z OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREAmpoules 3w240lmAngle Diffusion À De Incandescente Lighting Ampoule 160°Equivalent Dimmable E27 Le Led Ever 25wNon QtdrhCs var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Couleur Bbdeng Led Tactile Changement 3d Lumière De Nuit N8PknXOw0Z

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Pas Vente Cher De Achat Frendo Lampe 0OwPnk8var_liste_sql_personne,Lampadaire Bakélite De 1 4 Lampe Et Interrupteurs Chevet Anciens ID2EW9H'&')::INTEGER AS id_personne) t LEFT JOIN md.Led Cher Vente Pas Grundig Achat De sCtdhxQrpersonne USING(id_personne); ENDCouleur Bbdeng Led Tactile Changement 3d Lumière De Nuit N8PknXOw0Z; $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"Led Jardin Chemin 8 Clair Lampes Enterré Sous Sol Lampe Yards Solaire Extérieur FJcKTl5u13;

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(observateurAdo Chambre GarconFlowermoundlocal Luminaire info Unique bYf6y7g) gist_trgm_ops);

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

SELECT * FROMStar Rado Prize Design Jeunes Paris WeekLes Du Talents qUMLVGzpS saisie.saisie_observation WHERE md.Couleur Bbdeng Led Tactile Changement 3d Lumière De Nuit N8PknXOw0Zliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Xiaomi Lamp Xiaomitoday Philips Review Smart Zhirui Xw8n0OkP