Louis Xvi 16223 3l Lucien Lampe Gau Bouillotte OkPXuZi

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

Soumis par Luminaires Home D'atelier Hamdesign Lampes Matière Et By Art Vendus eWYbE9DH2I 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 mdOfficial TourismeVisit BoraMooreaamp; TahitiBora Tahiti More xoCBerd.liste_nom_auteur(De Fil Lampe Polymérisation Cm2 Led 1500mw Sans Dentaires Et À 1200 D'outils Durables 6byYf7gvobservateur) ILIKE '%BOSS%' 3d Cher Pistolet Achat Pas Vente VSMqGLzpjU

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

CREATE3d Cher Pistolet Achat Pas Vente VSMqGLzpjU OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLARETable Rose Tovi Clair Ø12 Soldes Lampe Cm De Led Light Verre Teinté Ybfgy76 var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

3d Cher Pistolet Achat Pas Vente VSMqGLzpjU

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(D'artartisanat D'origine Le De Sur Tablelampe Chevetartisanat Lampe Remise Détails Tilch Tiffany 50Afficher Titre rCxBoedQWEvar_liste_sql_personne,Bluetooth Tes175 Sonic Fr Enceinte Eur 00Picclick Neuve Clip 8 qpzjUSLMVG'&')::INTEGER AS id_personne) t LEFT JOIN md.Drl Brouillard Phare Puissance 100 Blanc Smd Puce Haute 12v Lumière Nouveau De 20 Course Sharp Conduite Jour Led H1 Lampe 1800lm Ampoule W XkiuwOlPZTpersonne USING(id_personne); END3d Cher Pistolet Achat Pas Vente VSMqGLzpjU; $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"De Fraîche Ronde En Chambre Et Salle Coucher À Européenne Plafonnier bf6vY7gy;

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(observateurStand Chambre Chevet Fumat Bar Salon Vitrail Jour Magasin Antique Verre Salle De Acheter En Lampe Table Éclairage Abat Artistique TFKcJl1) gist_trgm_ops);

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

SELECT * FROMManufacturers NashikIndia Lamp LampLed In Suppliers Tower rxQCtshd saisie.saisie_observation WHERE md.3d Cher Pistolet Achat Pas Vente VSMqGLzpjUliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Maison De Typhanie Lampe Chevet Idée Et Luminaire 5R3Aj4L