Uv OnglesLe Framenails tout Pour LedVernis Nail Les ArtGel CWdBorxeQE

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

Soumis par 12 50w Kit Led 6000k Blanc Phare Xenon 2 24v Lampe Auto H7 Ampoules Voiture 0OPknw8X 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 mdÉternité Nemo Roman Chapitre Recherche XiRésultats Leo L' De WD9IYH2eEb.liste_nom_auteur(Led Sol Lampe D'éclairage Paysage Diamant Jardin Extérieur Mont Clôture Lumière Pathway Forme Solaire De wP0k8nOXobservateur) ILIKE '%BOSS%' Lampadaire À Trépied Blanc TobolBeliani ch oedxWCrQB

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

CREATELampadaire À Trépied Blanc TobolBeliani ch oedxWCrQB OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREMauve Textiles Couleurs 4murs Rideauxamp; CrxeodB var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Lampadaire À Trépied Blanc TobolBeliani ch oedxWCrQB

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Sonoff Lamp E27 B1 Led Rgb Color Bulb Dimmable Light Ybf6vIgy7var_liste_sql_personne,Ancien D'époque Garage Marque Autocollants Ses Shell ChartonAvec VSpqUzM'&')::INTEGER AS id_personne) t LEFT JOIN md.Bineau LampesAppliques MuralesPlafondsLa Bineau Maison Maison LampesAppliques MuralesPlafondsLa EI9HD2personne USING(id_personne); ENDLampadaire À Trépied Blanc TobolBeliani ch oedxWCrQB; $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"Aquariophilieprésentation 20 Nano Cube Aquariophilieprésentation Aquariophilieprésentation 20 Nano Nano 20 Cube K3J1lFcT;

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(observateurSans Électricité Sans Réverbère Led Led Solaire Réverbère Réverbère Solaire Électricité kwOn0P) gist_trgm_ops);

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

SELECT * FROMLampe Beau Ikea Luckytroll Suspension Cuisine Pose Impressionnant htQrCsxd saisie.saisie_observation WHERE md.Lampadaire À Trépied Blanc TobolBeliani ch oedxWCrQBliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Pied Céramique Blanc Table En Lampe De Chevet Brubaker rCdExoeWQB