IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage SQL Discussion :

Requête complexe


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 37
    Points : 29
    Points
    29
    Par défaut Requête complexe
    Bonjour,

    j'ai une requête SQL que je dois modifié mais je n'arrive pas à faire ce que je souhaite.
    Je suis sous Postgres.

    Ci-joint la requête originale :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    select table4.storyhits, table4.noticehits, table4.prog_titre ,
    (select sum(cs.xduration) from cm_statistics cs where cs.prog_id = table4.prog_id and mime = 1 ) as sumreal,
    (select sum(cs.xduration) from cm_statistics cs where cs.prog_id = table4.prog_id and mime = 2 ) as sumqt,
    (select sum(cs.xduration) from cm_statistics cs where cs.prog_id = table4.prog_id and mime = 3 ) as sumwm,
    (select sum(cs.xduration) from cm_statistics cs where cs.prog_id = table4.prog_id) as totalstream 
    from (select table3.storyhits, table3.noticehits,table3.prog_id, cp.prog_titre from cm_programmes as cp left join (select table1.noticehits,table2.storyhits ,table1.prog_id from (select count(csn_id) as noticehits, prog_id from cm_stats_notice WHERE true group by prog_id) as table1
    LEFT OUTER JOIN (select count(css_id) as storyhits , prog_id from cm_stats_storyboards WHERE true group by prog_id) as table2
    ON table1.prog_id=table2.prog_id) as table3
    on table3.prog_id=cp.prog_id) as table4
    Je souhaite affiner la recherche et rajouter un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    where cp.catalogue_id in (300,301)
    que je pensais inserer entre le "cm_programmes as cp" et le "left join", mais cela ne marche pas.

    ma requete devriendrait donc :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    select table4.storyhits, table4.noticehits, table4.prog_titre , 
    (select sum(cs.xduration) from cm_statistics cs where cs.prog_id = table4.prog_id and mime = 1 ) as sumreal, 
    (select sum(cs.xduration) from cm_statistics cs where cs.prog_id = table4.prog_id and mime = 2 ) as sumqt, 
    (select sum(cs.xduration) from cm_statistics cs where cs.prog_id = table4.prog_id and mime = 3 ) as sumwm, 
    (select sum(cs.xduration) from cm_statistics cs where cs.prog_id = table4.prog_id) as totalstream 
    from (select table3.storyhits, table3.noticehits,table3.prog_id, cp.prog_titre from cm_programmes cp where catalogue_id in (300,301) left join (select table1.noticehits,table2.storyhits ,table1.prog_id from (select count(csn_id) as noticehits, prog_id from cm_stats_notice WHERE true group by prog_id) as table1
    LEFT OUTER JOIN (select count(css_id) as storyhits , prog_id from cm_stats_storyboards WHERE true group by prog_id) as table2
    ON table1.prog_id=table2.prog_id) as table3 
    on table3.prog_id=cp.prog_id) as table4
    Comment puis je affiner ma recherche correctement ?

    Merci par avance.

  2. #2
    vic
    vic est déconnecté
    Membre confirmé

    Profil pro
    Inscrit en
    Août 2002
    Messages
    431
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2002
    Messages : 431
    Points : 498
    Points
    498
    Par défaut
    Je le mettrais juste avant ") as table4"

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Juin 2002
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2002
    Messages : 37
    Points : 29
    Points
    29
    Par défaut
    Citation Envoyé par vic
    Je le mettrais juste avant ") as table4"
    Bonjour,

    Ca marche impeccable 8)

    Merci bien

    a+

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Requête complexe
    Par elmayor1983 dans le forum Langage SQL
    Réponses: 2
    Dernier message: 25/08/2005, 08h47
  2. [SQL] Requête complexe avec appel multiple à la même table
    Par Julien Dufour dans le forum Langage SQL
    Réponses: 9
    Dernier message: 14/04/2005, 14h12
  3. 3 tables avec requête complexe
    Par yamino dans le forum Langage SQL
    Réponses: 6
    Dernier message: 25/03/2004, 19h50
  4. Encore une requête complexe sur plusieurs tables
    Par DenPro dans le forum Langage SQL
    Réponses: 5
    Dernier message: 09/12/2003, 19h05
  5. Requête complexe sur plusieurs table
    Par DenPro dans le forum Langage SQL
    Réponses: 13
    Dernier message: 25/11/2003, 17h50

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo