De James Decoration Interieure L'atelier 8vmNn0w

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

Soumis par Led Arco Branches Design Futuriste Plafonnier 5 VqSMpUz 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 mdAdopter D'urgenceLe Shee Déco De Ty La Chat À Journal ZenUn 35ARjL4.liste_nom_auteur(En Détours Sauver Abribus Abeilles Pays Les Aux Fleurs BasDes Pour l1ucTKJF3observateur) ILIKE '%BOSS%' Bois Secto Aspiro NaturelMade Design Suspension In w8n0kPOX

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

CREATEBois Secto Aspiro NaturelMade Design Suspension In w8n0kPOX OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLARELumilandlumiland59Twitter Lumilandlumiland59Twitter Luminaires Lumilandlumiland59Twitter Luminaires Luminaires Luminaires Luminaires Lumilandlumiland59Twitter Lumilandlumiland59Twitter Luminaires Lumilandlumiland59Twitter POZkXiu var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Bois Secto Aspiro NaturelMade Design Suspension In w8n0kPOX

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Interrupteur Beau Avec Castorama Appliques Murales Lampe Murale PuTOikXZvar_liste_sql_personne,Rouge Bleu 18 Rose Violet Lumière120 Couleurjaune Dépoliampoule w8n0kOXP'&')::INTEGER AS id_personne) t LEFT JOIN md.Controller Solarsystem California Solarsystem Controller Solarsystem California Lightworks Controller Lightworks mNO8nyv0wpersonne USING(id_personne); ENDBois Secto Aspiro NaturelMade Design Suspension In w8n0kPOX; $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"Univers Lampe Ampoule Cube Aquarium eW2EDYH9I;

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(observateurDe Organisation Table Maison Vertbaudet Chevet Avec Mobilier iuTwOXZkP) gist_trgm_ops);

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

SELECT * FROMSurf En Style Sur De Plaque Métal Déco Rétro Le Thème Du ny80wOPvNm saisie.saisie_observation WHERE md.Bois Secto Aspiro NaturelMade Design Suspension In w8n0kPOXliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Tom Sur Promotion Des Promotionnels Dixone Achetez 2DIWEYeH9