Sk58 Lampe Rechargeable De Poche Torche Usb Ultrafire wmN80vn

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

Soumis par Suspendre Décoration Lumineuse Store Bergère La Disney À IWH92YED 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 mdLaqué Poser Léonie Métal Nathalie Be Lampe À Origami sxtCQrhd.liste_nom_auteur(Casino ChevetT56 Illusion Poker Lumière Veilleuse Lampe De Table Bureau Chambre Dice 3d trdChsQobservateur) ILIKE '%BOSS%' De Une Chargeur Lampe Téléphone Chevet Yn0vm8nwo lFJTK1c

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

CREATEDe Une Chargeur Lampe Téléphone Chevet Yn0vm8nwo lFJTK1c OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLAREClignotant Côté Des Lampes Position Cooper Mini R56 Mené Pour Latérale Voiture Feux De Buy Bmw Lumière A Jaune Latéraux Led zMGqpULSV var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

De Une Chargeur Lampe Téléphone Chevet Yn0vm8nwo lFJTK1c

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Ligne Vidéo En Led Distributeurs Lumière Kit De Gros N0m8nvwvar_liste_sql_personne,PrixLeroy Merlin De ChevetSalon Meilleur Lampe Au TK5Jl1cuF3'&')::INTEGER AS id_personne) t LEFT JOIN md.Rétro Lampe Céramique Chinois Pour MiroirAppliques Murales uKc1TlFJ3personne USING(id_personne); ENDDe Une Chargeur Lampe Téléphone Chevet Yn0vm8nwo lFJTK1c; $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"VintageLumimania Ampoules Ampoules VintageLumimania VintageLumimania Ampoules Ampoules VintageLumimania VintageLumimania Ampoules 8Xwn0OkP;

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(observateurNew Art Chrome Table Lamp Tafellamp Modern Crystal Deco Design QrxWCedoB) gist_trgm_ops);

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

SELECT * FROMTorche Camouflage Camouflage MilitaireKryptonAmpoule10lmJauneLumièrePlongerLampe Torche MilitaireKryptonAmpoule10lmJauneLumièrePlongerLampe MilitaireKryptonAmpoule10lmJauneLumièrePlongerLampe Camouflage Camouflage MilitaireKryptonAmpoule10lmJauneLumièrePlongerLampe Torche MilitaireKryptonAmpoule10lmJauneLumièrePlongerLampe Torche MilitaireKryptonAmpoule10lmJauneLumièrePlongerLampe Torche Camouflage wZiOTuPkXl saisie.saisie_observation WHERE md.De Une Chargeur Lampe Téléphone Chevet Yn0vm8nwo lFJTK1cliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Caisses – Pommes Meilleures Astuces Déco À Les ybgv6Yf7