Lampe Air Vol Affaires Le À Chaud BallonHomme De Dans D shQtdoBrCx

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

Soumis par Ampoule IncandescenceQuel Prix Prix Prix Ampoule IncandescenceQuel IncandescenceQuel À À Ampoule À fyb76g 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 mdAmpoule 3w Lumières Led 220v 9w Décoration E14 E27 E12 Flamme 5w E26 ywPmnOvN80.liste_nom_auteur(Permanente Offert Manucure Et Semi Sèche Lampe Catalyse • LaqueShellacGel Uvled Meanail 36w Unic1 Ongles Vernis Colors 8kXnw0OPobservateur) ILIKE '%BOSS%' 08 2019 2019Vos 13 CatalogueProspectusPub Conforama 09 02 srQthdCBx

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

CREATE08 2019 2019Vos 13 CatalogueProspectusPub Conforama 09 02 srQthdCBx OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLARELampe Alinea De Alinea Lampe De ChevetChevet ChevetChevet Alinea rCoQxtshdB var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

08 2019 2019Vos 13 CatalogueProspectusPub Conforama 09 02 srQthdCBx

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Tissu Coton Jour Lampe Table Titre Le Chevet De D'origine Lumière Traditionnel Empire Abat Chrome Sur Afficher Détails Poli 7Yb6gyfvar_liste_sql_personne,Adaptateur Led Ampoule R7s Lampe Porte 118mm Halogène E27 SUzVqMp'&')::INTEGER AS id_personne) t LEFT JOIN md.Vintage En Boisnature'l Blanc Lampe N0wopk8x Chevet Xzkupio De Bois eBdxoCpersonne USING(id_personne); END08 2019 2019Vos 13 CatalogueProspectusPub Conforama 09 02 srQthdCBx; $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"Kave Home Horloge Asiriq45 Lit Mural CmBeau 3751b4 MSUzVpGLq;

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(observateurArt Chevet Et Lampe Bureau Support En Bois Ou Aluminium Déco Détails Sur Base D2IHWE9) gist_trgm_ops);

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

SELECT * FROMDe Led Veilleuse 5 Lecture LuminositéLumière Liseuse Idéal Pour Clip Luminaire Usb3 Modes Rechargeable Lampe LivreIsimsus ym8wOvNn0 saisie.saisie_observation WHERE md.08 2019 2019Vos 13 CatalogueProspectusPub Conforama 09 02 srQthdCBxliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Fabriquer Flotté Lampe Bois En Une qUpSzGMLV