Précédent   Forum des professionnels en informatique > Bases de données > PostgreSQL > Requêtes
Requêtes Forum d'entraide sur les requêtes SQL spécifiques à PostgreSQL, les triggers, les vues, etc.
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 27/10/2011, 17h08   #1
Invité de passage
 
Inscription : mai 2008
Messages : 22
Détails du profil
Informations forums :
Inscription : mai 2008
Messages : 22
Points : 0
Points : 0
Par défaut Recherche full text

Bonjour

Ci-après une requête qui cherche dans des champs indexés. Le résultat de mes trois conditions "where" individuellement arrivent en quelques milli-sec. Mais les 3 ensembles (comme ci-après) arrivent en 7 secondes. Mes "or" ne sont pas une bonne idée??? Autre?

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
SELECT tblpublications.gid AS gid_publications,
tblpublications.title AS title
 
 FROM 
 
tblpublications
    LEFT  JOIN tblpublicationstokeywords ON tblpublications.gid =
      tblpublicationstokeywords.gid_publications
 LEFT  JOIN tlkpkeywords ON tblpublicationstokeywords.gid_keywords =
      tlkpkeywords.gid
 
 WHERE 
 
tblpublications.tsvector_abstract @@ to_tsquery('Teriflunomide')  OR
        tblpublications.tsvector_title @@ to_tsquery('Teriflunomide') OR
 tlkpkeywords.tsvector_keywords @@ to_tsquery(
 'Teriflunomide | 108605-62-5 | 282716-73-8')
 
 GROUP BY tblpublications.gid,
 tblpublications.title;

Merci

Martin
martinfa est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/10/2011, 17h54   #2
Modérateur
 
Avatar de al1_24
 
Homme Alain
Ingénieur d'études décisionnel
Inscription : mai 2002
Messages : 4 446
Détails du profil
Informations personnelles :
Nom : Homme Alain
Âge : 51
Localisation : France, Val de Marne (Île de France)

Informations professionnelles :
Activité : Ingénieur d'études décisionnel
Secteur : Conseil

Informations forums :
Inscription : mai 2002
Messages : 4 446
Points : 7 545
Points : 7 545
Si chaque requête s'exécute rapidement, tu n'as qu'à utiliser une UNION entre ces requêtes.
Par ailleurs, seule la troisième requête a besoin des jointures, les colonnes des tables jointes n'étant pas utilisées dans les deux premières.
De plus, ces jointures ne sont alors pas des jointures externes mais des jointures internes puisqu'une restriction est appliquée dans la clause WHERE sur une colonne d'une table jointe.
Plus besoin de faire de regroupement puisqu'il est fait par l'opérateur UNION.

Ce qui nous donne :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
  SELECT  pub.gid     AS gid_publications
      ,   pub.title   AS title
  FROM    tblpublications pub
  WHERE   pub.tsvector_abstract   @@ to_tsquery('Teriflunomide')
UNION
  SELECT  pub.gid     AS gid_publications
      ,   pub.title   AS title
  FROM    tblpublications pub
  WHERE   pub.tsvector_abstract   @@ to_tsquery('Teriflunomide')
UNION
  SELECT  pub.gid     AS gid_publications
      ,   pub.title   AS title
  FROM    tblpublications pub
      INNER JOIN
          tblpublicationstokeywords   wrd 
          ON  pub.gid = wrd.gid_publications
      INNER JOIN tlkpkeywords  kpk
          ON wrd.gid_keywords = kpk.gid
  WHERE   kpk.tsvector_keywords   @@ to_tsquery('Teriflunomide | 108605-62-5 | 282716-73-8')
;
__________________
Modérateur Langage SQL
Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
N'oubliez pas le bouton et pensez aux balises [code]
Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
al1_24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 28/10/2011, 14h23   #3
Modérateur
 
Inscription : octobre 2008
Messages : 1 508
Détails du profil
Informations personnelles :
Localisation : France, Paris (Île de France)

Informations forums :
Inscription : octobre 2008
Messages : 1 508
Points : 2 040
Points : 2 040
Citation:
Envoyé par martinfa Voir le message
Ci-après une requête qui cherche dans des champs indexés. Le résultat de mes trois conditions "where" individuellement arrivent en quelques milli-sec. Mais les 3 ensembles (comme ci-après) arrivent en 7 secondes. Mes "or" ne sont pas une bonne idée??? Autre?
Il faudrait le résultat d'EXPLAIN ANALYZE pour voir le plan d'exécution
estofilo est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h49.


 
 
 
 
Partenaires

Hébergement Web