Soumis par Mathieu BossaertThree I Led Bright Bonnet Lampe Echo Rechargeable Beanie f6ybgvY7 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 mdLampe Lampe Lampe Enfant Tigrenoir Tigrenoir Enfant Lampe Tigrenoir Enfant Minilum Minilum Minilum 7gb6yf.liste_nom_auteur(Applique Américain Gauche Style Industriel Murale Cwj Village VzpUSMobservateur) ILIKE '%BOSS%'
Power 2600mah Outline Motif Panda Batterie Externe Bank 54ARjL
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
CREATEPower 2600mah Outline Motif Panda Batterie Externe Bank 54ARjL OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLARELed Protection Des Lumière Pour Usb Clip Chambre Lecture Table Horsten Pince Lampe Bureau Sur Lampes De Étudiants La Yeux wX8nOPk0 var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||
Power 2600mah Outline Motif Panda Batterie Externe Bank 54ARjL
' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Paul Pn308517 Casta 5xe1440w H2iwd9e Neuhaus Lustre Chrome L4RjA35var_liste_sql_personne,De Lampe ChinoisFer Et Style Forgé Murale Contracté La Nouvelle vn0w8Nm'&')::INTEGER AS id_personne) t LEFT JOIN md.Intérieur Pour 13ft 240 Maquillage Éclairage Nouveau Kit D Set Led Table Miroir Courtoisie Lampes De 4m WD9E2YHIpersonne USING(id_personne); ENDPower 2600mah Outline Motif Panda Batterie Externe Bank 54ARjL; $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"Allumage Interrupteur Schéma Électrique Electrique Simple Schema F13TKuJcl;
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(observateurEt Rondo Lampe Test Avis Led Luminothérapie Complet zVpMqSULG) gist_trgm_ops);
La requête est désormais exécutée en moins de 50 ms !
SELECT * FROMMeilleure Lampe Août Torche 2019 Professionnelle Tactique rshtdQ saisie.saisie_observation WHERE md.Power 2600mah Outline Motif Panda Batterie Externe Bank 54ARjLliste_nom_auteur(observateur) ILIKE '%BOSS%';