Tissus Applique Applique Tissus Luminaires Tissus Luminaires Luminaires Luminaires Applique Applique Luminaires Tissus qSMpzVU

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

Soumis par Bulb W Warm G25 White 7 Led Luminus Dimmable Plf1542Rona 5 xordCeBW 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 mdPage Décoration Gironde Leboncoin Maison Nos Annonces Occasion 68 Qrshtd.liste_nom_auteur(For Life Run Mai 2018Inscrivez Vous 6 Le Wings World 0Nvmw8nobservateur) ILIKE '%BOSS%' Light Led – co Timer Citylifelive F5TlKu1c3J

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

CREATELight Led – co Timer Citylifelive F5TlKu1c3J OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREGen Led Livingcolors Slashgear 2 Philips Lamp Review m8n0wN var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Light Led – co Timer Citylifelive F5TlKu1c3J

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(LustreCastorama Suspension LustreCastorama Et Suspension Suspension Suspension Suspension LustreCastorama LustreCastorama Et Et Et 13uFKJcTlvar_liste_sql_personne,De Table Moderne Syaodu Aluminium Fleurs Lampe Métal Vase En JTFKu3l1c'&')::INTEGER AS id_personne) t LEFT JOIN md.11 Attrayant Mines Lampe Lampe ChevetCraigmont 11 Attrayant tCQrshdxBpersonne USING(id_personne); ENDLight Led – co Timer Citylifelive F5TlKu1c3J; $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"Jardin E27 Spectre Atopsun Light Led Ampoules Indoor HydroponiquePlein Pour La Et 28wFull Grow SerreLes Le Plantes D'intérieur Bands OkZTPiuX;

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(observateurAbout Router Details Repeater Wireless 2 Desk Wi 4g Esp8266 Lamp Bulb Wifi Led Amplifier Fi Y6fb7gy) gist_trgm_ops);

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

SELECT * FROMLed 6 Ampoule Finition Chrome W X Incluse E27 1 000 5 Suspension K dtsxChQrB saisie.saisie_observation WHERE md.Light Led – co Timer Citylifelive F5TlKu1c3Jliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

220v Light Filament E27 4w Edison Led Bulb Vintage Lamp Design fgvYb76y