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 :

requete complexe sur 3 tables


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2007
    Messages : 45
    Points : 38
    Points
    38
    Par défaut requete complexe sur 3 tables
    salut
    voici mon probleme j'ai 3 tables lpr,previsions et realise
    lpr(lpr,famille)
    previsions(lpr,montant)
    realise(lpr,montant)
    lpr et realise sont relié par une jointure 1,n
    lpr et previsions sont relié par une jointure 1,n
    je veux calculer le montant realise et montant realise sur celui prevu groupé par famille de lpr
    comment faire?

  2. #2
    Membre éclairé Avatar de grabriel
    Inscrit en
    Septembre 2006
    Messages
    946
    Détails du profil
    Informations forums :
    Inscription : Septembre 2006
    Messages : 946
    Points : 730
    Points
    730
    Par défaut
    Salut,

    Tu as des tables qui ont les memes noms de champ et tes explications ne sont pas suffisement claire est-ce que tu peux faire un petit MCD histoire d'y voir plus claire et
    je veux calculer le montant realise et montant realise
    C'est vraiment pas claire...

    Pour ce qui est du
    groupé par famille de lpr
    tu peux utiliser un group by.

  3. #3
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 802
    Points
    30 802
    Par défaut
    Compte tenu des doubles regroupements, il faut passer par une table dérivée :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    select    F.FAMILLE
        ,    sum(R.MONTANT)    as REALISE
        ,    sum(R.MONTANT) / sum(P.MONTANT)
    from
            LPR    as F
        inner join
            REALISE    as R
            on     F.LPR = R.LPR
        inner join
            (    select    LPR
                    ,    sum(MONTANT)    as MONTANT
                from    PREVISIONS
                group by LPR
            )    as P
            on    F.LPR = P.LPR
    group by
            F.FAMILLE
    ;
    Une question du même ordre a été posée il y a peu de temps...
    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
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2007
    Messages : 45
    Points : 38
    Points
    38
    Par défaut
    salut
    merci pour la réponse
    et si j'utilise SGBD oracle9i et puisque elle admet pas le INNER JOIN comment faire cette meme requete?
    merci

  5. #5
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 802
    Points
    30 802
    Par défaut
    Citation Envoyé par oasma
    salut
    merci pour la réponse
    et si j'utilise SGBD oracle9i et puisque elle admet pas le INNER JOIN comment faire cette meme requete?
    merci
    Utiliser un SGBD conforme au standard SQL

    ou effectuer un produit cartésien filtré sur l'expression de jointure.
    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
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Mars 2007
    Messages : 45
    Points : 38
    Points
    38
    Par défaut
    salut
    svp explique moi un peu plus ce que tu veux dire par:effectuer un produit cartésien filtré sur l'expression de jointure.
    merci

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

Discussions similaires

  1. Requete complexe sur 2 tables avec dates
    Par fusee2013 dans le forum Langage SQL
    Réponses: 3
    Dernier message: 11/08/2013, 19h56
  2. Requete SQL complexe sur plusieurs tables
    Par vnk600 dans le forum Langage SQL
    Réponses: 7
    Dernier message: 13/12/2009, 11h22
  3. Requete COUNT sur 3 tables
    Par Le-Cortex dans le forum Requêtes
    Réponses: 3
    Dernier message: 08/09/2005, 10h39
  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