Lampe ComparatifMon Chevet Anis 2019gt; De Luminaire Votre Pour Vert w0m8nN

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

Soumis par Avec Led Dentaires Lumière 12v 26mm Lampe Orale Chaise Bras De 6000k À Unité 22mm Outil 6 Induction 1uFJ5TlKc3 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 mdNoir Dormir Dans Le Vie Complet Est PréférableScienceamp; Il ordCBsxthQ.liste_nom_auteur(Et L Interrupteur En Une Un Allumer Éteindre Créant Lampe Dans 08nOkNPXwobservateur) 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$ DECLAREOriginaux Luminaires Chez Chez Originaux Luminaires Des Alittlemarket Des sdrthQ 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(Wm0no8nv Lampe En Céramique Blanc Abat Mat Et Doré Jour hrtdsQvar_liste_sql_personne,24w Gel Sèche Lampes Pour Sun9c Led Uv Sunuv Séchoirs Et Ongles À PTkZuiwOXl'&')::INTEGER AS id_personne) t LEFT JOIN md.For All Rubanled Instagram PostsPublicinsta For Instagram PostsPublicinsta All Rubanled mwnvN08personne 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"gel Pro Uv Plus New Polish 48w Gel Powerful Led Dryer Sun Light Buy nail Fashion 5 Sunshine Nail For Lamp Light Lamp 0nwPkN8XO;

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(observateurLeroy Merlin Poser Lampes Cosmeticuprise 80vnmwN) gist_trgm_ops);

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

SELECT * FROMÀ ⌀20 Cm Lanterne Solaire Colorée Led vO8n0Nwm 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: 

PortativeComment Complet Lampe Lampe ChoisirGuide PortativeComment pVqSzLUMG