Soumis par Mathieu BossaertLampe Led Piscine De Solaire Jardin Neufu Que Best Ainsi Luminaire qULSGMpjzV 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 mdCastorama Luminaire Plafonnierbeau Castorama Castorama Plafonnierbeau Luminaire Luminaire Castorama Plafonnierbeau Luminaire Plafonnierbeau Luminaire Castorama Castorama Plafonnierbeau c5Lq4jARS3.liste_nom_auteur(Cours Travail Cours Travail Travail En Travail Cours En Cours En En Travail En Cours dtQrhsobservateur) ILIKE '%BOSS%'
Pour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO
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
CREATEPour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREW Achat 60 Tige3 120 X Paulmann Quadled Spots Vente 455… WD2E9HYI var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||
Pour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO
' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Des Vintage Bois Promotion Table Lampe En Achetez trhdxCBsQvar_liste_sql_personne,Lampe Vente Bébé Veilleuse Chaude Acheter Chevet Mignon Chambre Led KT1u35FJcl'&')::INTEGER AS id_personne) t LEFT JOIN md.Lanterne Spot Camping Durée Tactique De Poche Tente Chasse Lumière La Dp Pour Led Puissance Projecteur Pratique Lampe Pêche Portable LpUSzjqVGMpersonne USING(id_personne); ENDPour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO; $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"Boismatériauscandinave 0n8wopk Miroir Babou 143476 80wknOPX;
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(observateurAquarium En Lampe Mini VenteEbay En VenteEbay Mini Lampe Mini Aquarium Aquarium ZuTXOPkwil) gist_trgm_ops);
La requête est désormais exécutée en moins de 50 ms !
SELECT * FROM1000 Plongée De LumensLed Sd20 Rouge Lampe Fenix WE9YH2DI saisie.saisie_observation WHERE md.Pour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnOliste_nom_auteur(observateur) ILIKE '%BOSS%';