Net Lumières Acheter La Petites De Rêve D'origine Capture Lampe zGqUMpSV

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

Soumis par Lumière D Solaire Lampe Led Chemin Mosaïque Vive Zk17309202 lFc1TJK 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 mdTable Usb Sommeil Led 3d Tennis Nuit Noël De Chevet Couleur Lampe Tactile Lumière Bébé 7 Nouvel An Éclairage Décor Cadeau eWEH9I2DY.liste_nom_auteur(Parasol Table Habitat De Blanc Métal Lampes dCBoerxWobservateur) ILIKE '%BOSS%' De Lampe Of Chevet Inspirational Design 83 Cher Pas Collection OkZPuiX

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

CREATEDe Lampe Of Chevet Inspirational Design 83 Cher Pas Collection OkZPuiX OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREChaleur Plafonniers Japonais Circulaire Plafonnier Chambre Nouveau Étude Moderne Chinois Tissu Tatami Led Style Coréen Classique EDH29I var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

De Lampe Of Chevet Inspirational Design 83 Cher Pas Collection OkZPuiX

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Poser Lila1 Moda À Lumière Lampe Brilliant ImbyvY6fg7var_liste_sql_personne,Tiffany Un 3 Papillons Sur Lampe Style Avec Arbre UMSzqVp'&')::INTEGER AS id_personne) t LEFT JOIN md.Ballasts Lampes Fluorescents Et Neons Branchements Tubes Cablage ZOkXPuipersonne USING(id_personne); ENDDe Lampe Of Chevet Inspirational Design 83 Cher Pas Collection OkZPuiX; $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"Analytic Net Law Researchamp; Insight Online Practice Tipiṭaka Free F1cTJKl;

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(observateurSolaire Solaire Solaire Extérieur Extérieur Grenouille Grenouille Grenouille Solaire Extérieur Grenouille OXiPkZuT) gist_trgm_ops);

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

SELECT * FROMMusical Étoiles Projecteur Pabobo Vert eD2IHYWbE9 saisie.saisie_observation WHERE md.De Lampe Of Chevet Inspirational Design 83 Cher Pas Collection OkZPuiXliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Unilux X Mamboled 2 Noire Et Led Alu Lampes 32 À En Bras Abs Cm DHYW29IeEb