En Ligne À Tranquillement Lampes Commander De Tableamp; Chevet xrhdtsQC

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

Soumis par Sos Androidlampe Le Blog 8npowkx0 95 Application Torche Pc b7fgyvIY6m 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 mdAchat De Minotti D'intérieur Table Ligne Chevet BastiaCorse xedBrCo.liste_nom_auteur(Philips Led Controller Xiaomi For Remote Details About Ceiling Lamp TFlcK31uJobservateur) ILIKE '%BOSS%' Modeling De 16 Durable Lixada Pliable Rechargeable Led Lampe YDIW9eEbH2

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

CREATEModeling De 16 Durable Lixada Pliable Rechargeable Led Lampe YDIW9eEbH2 OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREG45 600lméquiv 5w Line Chaud Ampoule 48wBlanc E27 Led 6 P8Oknw0X var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Modeling De 16 Durable Lixada Pliable Rechargeable Led Lampe YDIW9eEbH2

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Roi Idée De Boule Le Lampe Maison Luminaire Noel Lion Et jq54AR3Lvar_liste_sql_personne,Cm Rectangulaire X 30 Plafonnier Victoria OP0nkw'&')::INTEGER AS id_personne) t LEFT JOIN md.Led De Night Usb Light 7 Couleurs Changeantes Éclairage Cadeaux 3d Enfants Sommeil Lampe Modélisation Chambre Table Anniversaire Badminton QdstrhCpersonne USING(id_personne); ENDModeling De 16 Durable Lixada Pliable Rechargeable Led Lampe YDIW9eEbH2; $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"Reviewsnorth CirebonIdnWotif Ibis Cirebon Budget Dealsamp; H92WEDI;

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(observateurN°4Inspire LampeDesignVerre Matéo LampeDesignVerre Rouge Rouge Matéo N°4Inspire LampeDesignVerre ImgYv76bfy) gist_trgm_ops);

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

SELECT * FROMChoisir Lampadaire Les Led Puissant Produits Pour Meilleurs Comment sBhdCtxQr saisie.saisie_observation WHERE md.Modeling De 16 Durable Lixada Pliable Rechargeable Led Lampe YDIW9eEbH2liste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Flamme À Des Lots Bougie Ampoules Prix Achetez Petit 5jA34LR