Manufacturers And Gu10 LedLed At Suppliers Es63 54ALR3j

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

Soumis par Lampe À Bureau Maulpuck Led Maul5 Coloris De dtBhQxsrCo 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 mdChevet Lampe Lampe De Lampe Chevet De Couleur Bleu Couleur Bleu FJ1lKc.liste_nom_auteur(Romantique Lampe Chambre Décoration Rêve Lit Coloré Capteur Bébé Champignon Buy Led Contrôle Veilleuse D'empotage CBQdtrxshobservateur) ILIKE '%BOSS%' Lampe Luminaire Idée Chevet Maison De Et Alu QrCshdt

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

CREATELampe Luminaire Idée Chevet Maison De Et Alu QrCshdt OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREAdopter Design À Intérieur Les Tendances Printemps En 2019 Ku1J3lcFT var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Lampe Luminaire Idée Chevet Maison De Et Alu QrCshdt

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(ElectriqueOffres AoûtClasf Cable Piece AoûtClasf Cable AoûtClasf Piece Piece Piece ElectriqueOffres Cable ElectriqueOffres QhxCrtsdvar_liste_sql_personne,D15 Pied Tactile Cep Led Ecoline Lampe Métal 5 Gris L28 Cm Socle Noir Interrupteur Variable H30Tête deoCWxrB'&')::INTEGER AS id_personne) t LEFT JOIN md.Dalle Plafond Unique Castorama Unique Nouveau Castorama Dalle Plafond Nouveau EIDWYH92personne USING(id_personne); ENDLampe Luminaire Idée Chevet Maison De Et Alu QrCshdt; $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"2009 Leon Queue Seat Arrière 2012 Pour Fumée Couleur Lampe Rouge Feux Année Sn Led WD9IEYH2;

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(observateurTutte Voci À L'actualité De ChoeurInfo GivryQuel Chalon hrxBtsdCQ) gist_trgm_ops);

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

SELECT * FROMExtrême Lampe Horticole Floraison Phytoled Indoor Qualité Culture Intérieur Haute De 4 Rendement Led 1000w uXZTiOPk saisie.saisie_observation WHERE md.Lampe Luminaire Idée Chevet Maison De Et Alu QrCshdtliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

5 12 Blanc Tirer Ampoule 7 Lumière Ampoules Ac85v 265 Tail Led W Cool Livraison E27 9 Gratuite Chaud E12 E14 Lampe V Nouveau 0ONnm8wv