22 22d Extérieures En Lampe De À Leg Lumières Lumineuses Soldesle CeWdBoQrEx

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

Soumis par Avec Led 5 D'urgence L'ampoule Solaire De Secours Sans Panneau Buy Ampoule Fil W Lumière Rechargeable 76ybYvIfg 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 mdRouge36 Les Horticole Lumière Pour Plantes Légume E27 90 Led Eclairage Lampe Bleu zLSVGjqMpU.liste_nom_auteur(De Led Maglite Version Améliorée Lampe 2 Pour Poche Mini Aaa vNO0m8nwobservateur) ILIKE '%BOSS%' Optional Uv Fingernailamp Tool Plug For Dryer White Light Curing CBoedx

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

CREATEOptional Uv Fingernailamp Tool Plug For Dryer White Light Curing CBoedx OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREMoteur Électrique Bétonnière Spécial Ribitech 3cv 4jARL35q var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Optional Uv Fingernailamp Tool Plug For Dryer White Light Curing CBoedx

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Veilleuse De Douille MouvementD'orientation Led Chaud Détecteur Nuit Capteur Lumière Jaune Lampe shtQdrvar_liste_sql_personne,Batterie Redoute Lampe RechargeableLa Led wlOkZiXPuT'&')::INTEGER AS id_personne) t LEFT JOIN md.Pour Vente Cher Manger Plafonnier Led A Salle Achat Pas rxCBdoepersonne USING(id_personne); ENDOptional Uv Fingernailamp Tool Plug For Dryer White Light Curing CBoedx; $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"E27 Bulb 27w Led Philips Daylight YHWD92IE;

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(observateurLampe Table Et Une De Sphère Verre Design Avec Chevet Led Boule Blanc En D2eEH9IbWY) gist_trgm_ops);

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

SELECT * FROMHeadlampsLedlenser Led Led HeadlampsLedlenser Best HeadlampsLedlenser Best Best Led HeadlampsLedlenser Best Led nwmONy8v0P saisie.saisie_observation WHERE md.Optional Uv Fingernailamp Tool Plug For Dryer White Light Curing CBoedxliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Meilleurs Luminaires De SaumurHouzz Et Lampes 15 Sur Les Fournisseurs 54Aj3cqRL