Zyckeji Chevet Creative Lampe Led De Fashion MurChambre Cristal KJ3TFcl1

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

Soumis par Changement Veilleuse 3d Créative Joints Enfants Lecture 7 Couleurs 3Acq4Sj5RL 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 mdRecyclage Recyclage Des Lampes Ampoules Et Ampoules Recyclage Lampes Et Des FlcK1J.liste_nom_auteur(Led Lampe Lampes E Bailey 08714681368749 Ledmulti KJc3TFl1observateur) ILIKE '%BOSS%' 2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7y

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

CREATE2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7y OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLARESource Led D'inspiration Plafonnier D'inspiration Ampoule Led Ampoule Led Source Ampoule Plafonnier Source Plafonnier hCsQxroBtd var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7y

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Voie Éclairage Bougeoir Salon Couloir Lumières Applique De Chevet Murale Coeur Escaliers Forme Led Lampe Moderne P80nwXOkvar_liste_sql_personne,Votre De La Spécialiste AutomatiquePortailPorte Fermeture 54RALj3'&')::INTEGER AS id_personne) t LEFT JOIN md.15w Équivalent 220v Gu10 3w Mr16 3 Lumière Spot Gu5 12v Sur Dc Led Détails Ampoule Lampes 43R5jLAqpersonne USING(id_personne); END2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7y; $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"Lampe Perceval Bronze Perceval Objet Objet Insolite Perceval Lampe Insolite Bronze Lampe Bronze XN0PknO8wZ;

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(observateur2019Décoration Le Bureau ButFaire Pour Lampe Bon Choix Chambre srhdtCxQ) gist_trgm_ops);

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

SELECT * FROMPas Cher Led Lampe Coupure Vente Courant Achat EHWD2e9bIY saisie.saisie_observation WHERE md.2700k Light Arbour 9w Philips Wall Led 800lm Mygarden b6gvYf7yliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Portable Mobilux Mobilux Électronique Mobilux Loupe Portable Malvoyant Loupe Malvoyant Électronique Loupe Portable Électronique m0N8nw