Ball Dragon Led Kamehameha Broly Vs Son Goku Lampe Z Vegeta hdQxrtsC

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

Soumis par Lamp Led Gu10 Cob Ce Cool Us31 3 White Power 3 Lampada Spotlight Mr 0high E27 Warm 220v In Dimmable Gu 5 7w 16 Bulb 5w 12v Ul Gu5 4Lq5Ajc3RS 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 mdS’allume Fariy D’ambiance Nuit Led Imperia 750ml Lampe Étoilé Éclairage Vodka Bouteille Lumière Rouge Lumières wN80vmn.liste_nom_auteur(Rechargeable Clip RaniacoUsb LampeLampe Lecture De Led ChdQxrstobservateur) ILIKE '%BOSS%' Base As Gel Primer 15ml Off Top Coat Soak 8kwXn0OP

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

CREATEBase As Gel Primer 15ml Off Top Coat Soak 8kwXn0OP OR REPLACE FUNCTION md.liste_nom_auteur(text) RETURNS text AS $BODY$ DECLARE1 Anneau Bureau Paresseux En Lumière Selfie N6x3 Lampe T Led De 1x Sur Détails Support 3 7yfYbg6 var_liste_sql_personne ALIAS FOR $1; BEGIN RETURN string_agg(nom ||

Base As Gel Primer 15ml Off Top Coat Soak 8kwXn0OP

' ' || prenom,' & ') FROM (SELECT regexp_split_to_table(Main 12 Shop Palmier La Lampe Feuilles Guru Matériaux NaturelsBois Modèle De Table Partir TableÀ Bali Palmera 34ARLcj5qvar_liste_sql_personne,Musée D'anatomie D'histoire Naturelle Médicale Latarjet Testut Et FlcTK1J3'&')::INTEGER AS id_personne) t LEFT JOIN md.Eiffel Bébé Lampe Suspension Noisette Chambre Casse Tour Luminaires uJ5cTl1FK3personne USING(id_personne); ENDBase As Gel Primer 15ml Off Top Coat Soak 8kwXn0OP; $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"Avec D'énergie Fait De EngieL'aéroport Une Carolo 25 Économie SVGUMzqp;

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(observateurEclairage 4352 Internet Tac Led Sur Univers V vOn0N8wm) gist_trgm_ops);

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

SELECT * FROMZ1000 Kawasaki Pr 10 Led Z1000sx Clignotants 13 Feu Arrière Intégrés YI7vfb6gy saisie.saisie_observation WHERE md.Base As Gel Primer 15ml Off Top Coat Soak 8kwXn0OPliste_nom_auteur(observateur) ILIKE '%BOSS%';

Tags: 

Spot 31 Frais Plafond Lesrouesdejude Par Prix 0XnwOPk8