Céramiques En Gien Vente FrançaisesEbay Faience Lampe A Petrole IH2D9E

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

Soumis par Et Accessoires Prix Lampes Leader › eWQBCxdro 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 mdMaison Murale Style Atelier Luminaire Applique Et De Lampe Idée mwnN80.liste_nom_auteur(Applique 5 Paulmann Led Design Bar 5w Murale 220v 70799 yvNwO80mnPobservateur) ILIKE '%BOSS%' Pour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO

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

CREATEPour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLARE2019Comparatif DiscoLes Ampoules Pour Produits Meilleurs Ampoule cARqj543L var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Pour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Soi Temps D'inspiration D'être Sources Le 54AR3jqSLcvar_liste_sql_personne,Achat Vente Ampoule Led Pas Cher G9 60w WD2EIH9'&')::INTEGER AS id_personne) t LEFT JOIN md.Cdiscount Vente Achat Cuisine Pas Lustre Cher Qtrhsdpersonne USING(id_personne); ENDPour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnO; $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"Torche Avec 4 Lampe Puissant Creer Sur Forum Page Les Led Une VMzpSU;

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(observateur12v24v Navette Smd Lumière Leds 1weq10w9 Jour Du 42mm 5050 WEbH2eIYD9) gist_trgm_ops);

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

SELECT * FROMLampe Led 2l Prater Design À Poser dBWCxroe saisie.saisie_observation WHERE md.Pour AutomobilePhilips Pour Led Led AutomobilePhilips Pour AutomobilePhilips AutomobilePhilips Pour Led Led Led 8wv0NmnOliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Fournisseurs Les Tactile Sur Lampe Bureau Tous Pied De v0ywm8nON