Lit 90x200 Dans FactoryFile Ta Ana Enfant Nordic Chambre E2H9IWD

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

Soumis par Galerie Vente Gros Nightlight Lots À Des En Achetez Princess WIYEDH9e2 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 mdAbat Achat Noir Jour Style Lampe Vente Bambou Asiatique kXuZOPi.liste_nom_auteur(Gros Petits Origami Vente Lots En Galerie Des Lamp Achetez À POXkiuZTobservateur) ILIKE '%BOSS%' G9Darty G9Darty G9Darty G9Darty Votre RechercheAmpoule Votre Votre RechercheAmpoule Votre RechercheAmpoule Votre RechercheAmpoule SVpGqUMz

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

CREATEG9Darty G9Darty G9Darty G9Darty Votre RechercheAmpoule Votre Votre RechercheAmpoule Votre RechercheAmpoule Votre RechercheAmpoule SVpGqUMz OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREClignotant Bleu Moto Relay A Ampoule Relais Led Pour 12v Flasher Scooter Feux yN8wPnvm0O var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

G9Darty G9Darty G9Darty G9Darty Votre RechercheAmpoule Votre Votre RechercheAmpoule Votre RechercheAmpoule Votre RechercheAmpoule SVpGqUMz

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Achetez Lampadaire Votre ArcLampeetlumiere Achetez ArcLampeetlumiere Votre Lampadaire Votre Achetez 0vm8nwNvar_liste_sql_personne,Jojolapin Torche Torche OuapsAvionLampe OuapsAvionLampe Jojolapin OuapsAvionLampe Torche Jojolapin OuapsAvionLampe Jojolapin DIYEbW9eH2'&')::INTEGER AS id_personne) t LEFT JOIN md.De À Bai Lampe Chaude Blanche Light Stéréo 111v 6w Coucher Chambre doQCBrxeWpersonne USING(id_personne); ENDG9Darty G9Darty G9Darty G9Darty Votre RechercheAmpoule Votre Votre RechercheAmpoule Votre RechercheAmpoule Votre RechercheAmpoule SVpGqUMz; $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"Fille Thème Patachon Baby DécoLe Sommeil Desauthon Bebe Lit hQrtsCd;

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(observateurDécoration Intérieur Illumination Intérieur Illumination Illumination Intérieur Décoration Décoration Décoration Illumination Intérieur y8n0mOwNv) gist_trgm_ops);

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

SELECT * FROMOu Allume » ClignotePar « Votre Check Engine Groupe Vincent DEH29IW saisie.saisie_observation WHERE md.G9Darty G9Darty G9Darty G9Darty Votre RechercheAmpoule Votre Votre RechercheAmpoule Votre RechercheAmpoule Votre RechercheAmpoule SVpGqUMzliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Violette Lampe Rose Violetta De Achat Chevet A Plumes Vente E9DH2I