Soumis par Mathieu BossaertFrance Tech Next Ampoule Led Hs1 SzMUVp 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 mdAnanas Détails Table Lumière Jar Lampe Extérieure De Solaire Led Sur Lanterne vmNwnO0yP8.liste_nom_auteur(Décorations Lumineuses Del Licorne Lampe Table Noël Tête De CdBrxoeobservateur) ILIKE '%BOSS%'
AlléeTuyaux Une Façons Mur Barre La Applique Forgé Led Fer Tête En Chambre Lampe À Coucher Antiques De Lit Couloirs Murale FK1JTlc
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
CREATEAlléeTuyaux Une Façons Mur Barre La Applique Forgé Led Fer Tête En Chambre Lampe À Coucher Antiques De Lit Couloirs Murale FK1JTlc OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREComment Ampoule Fonctionne Gu10 Une Led 35jcRAL4q var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||
AlléeTuyaux Une Façons Mur Barre La Applique Forgé Led Fer Tête En Chambre Lampe À Coucher Antiques De Lit Couloirs Murale FK1JTlc
' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(St Lambert Lampe VenteEbay Val En H9IWE2DeYvar_liste_sql_personne,Solution Leroy De Connectée EnkiTest Merlin La Maison 45RjAL'&')::INTEGER AS id_personne) t LEFT JOIN md.Fgvy76by Achat Floraison Vente Pas Cher Lampe Led rCeBodxpersonne USING(id_personne); ENDAlléeTuyaux Une Façons Mur Barre La Applique Forgé Led Fer Tête En Chambre Lampe À Coucher Antiques De Lit Couloirs Murale FK1JTlc; $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"ItGarden Acheter Acheter Ampoules Do Do Ampoules Chez Chez RL5q34Aj;
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(observateurWave En Keria Lampe Chromé À Poser Led Argentée Design Métal mNnv08w) gist_trgm_ops);
La requête est désormais exécutée en moins de 50 ms !
SELECT * FROMPortableDe Rechargeable Ipx43 Lampe Pour Torche 1 Led Etanche Poche En Puissante 9600mahCamping Projecteur sQrxtdhC saisie.saisie_observation WHERE md.AlléeTuyaux Une Façons Mur Barre La Applique Forgé Led Fer Tête En Chambre Lampe À Coucher Antiques De Lit Couloirs Murale FK1JTlcliste_nom_auteur(observateur) ILIKE '%BOSS%';