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 :

[débutant] Jointure + Count


Sujet :

Langage SQL

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 56
    Par défaut [débutant] Jointure + Count
    Bonjour, il se pose à moi un problème sur une réquête impliquant une jointure et un count. Voici, de manière simplifiée, les deux tables concernées :

    motif(code_motif, libélé_motif)

    décision(num_demande, code_décision, code_motif)

    Le but de la requête est d'afficher le nombre d'occurences de chaque motif à partir de l'ensemble des décisions. En clair :

    motif_1 -> 12
    motif_2 -> 3
    motif_3 -> 0
    ...
    motif_10 -> 23

    Voici ma requête à l'heure actuelle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT motif.libélé_motif, Count(motif.code_motif) AS compteDecode_motif
    FROM motif INNER JOIN décision ON motif.code_motif = décision.code_motif
    WHERE (décision.code_décision="0")
    GROUP BY motif.libc_motif;
    Le problème est quelle ne m'affiche pas le motif_3 puisqu'aucune occurence n'est trouvée.

    Merci d'avance pour vos solutions.

  2. #2
    Membre Expert Avatar de vttman
    Homme Profil pro
    Développeur "couteau mosellan"
    Inscrit en
    Décembre 2002
    Messages
    1 140
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur "couteau mosellan"
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 140
    Par défaut Re: [débutant] Jointure + Count
    Citation Envoyé par Yann21
    Bonjour, il se pose à moi un problème sur une réquête impliquant une jointure et un count. Voici, de manière simplifiée, les deux tables concernées :

    motif(code_motif, libélé_motif)

    décision(num_demande, code_décision, code_motif)

    Le but de la requête est d'afficher le nombre d'occurences de chaque motif à partir de l'ensemble des décisions. En clair :

    motif_1 -> 12
    motif_2 -> 3
    motif_3 -> 0
    ...
    motif_10 -> 23

    Voici ma requête à l'heure actuelle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT motif.libélé_motif, Count(motif.code_motif) AS compteDecode_motif
    FROM motif INNER JOIN décision ON motif.code_motif = décision.code_motif
    WHERE (décision.code_décision="0")
    GROUP BY motif.libc_motif;
    Le problème est quelle ne m'affiche pas le motif_3 puisqu'aucune occurence n'est trouvée.

    Merci d'avance pour vos solutions.

    Dans décision ?

    Si oui remplacer
    INNER JOIN par LEFT JOIN ...
    S'il n'y a pas de décision pour un des motifs =>
    décision.code_décision sera à NULL pour le motif considéré

    Ce qui nous donne ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT motif.libélé_motif, Count(motif.code_motif) AS compteDecode_motif
    FROM motif LEFT JOIN décision ON motif.code_motif = décision.code_motif
    WHERE (décision.code_décision="0") or 
    (décision.code_décision is null)
    GROUP BY motif.libc_motif;
    A tester ...

  3. #3
    Membre expérimenté
    Avatar de MashiMaro
    Profil pro
    Inscrit en
    Février 2003
    Messages
    180
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2003
    Messages : 180
    Par défaut Re: [débutant] Jointure + Count
    Citation Envoyé par Yann21
    libélé_motif
    Euh petite correction d'orthographe : libelle_motif

    Petit conseil : évite les accents dans les noms de colonnes. D'ailleurs, tu ne travaillerais pas sous ACCESS ?

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 56
    Par défaut
    Effectivement, la phrase était ambigüe : le problème vient du fait que dans l'ensemble des décisions, il existe des motifs qui ne sont jamais invoqués.

    La requête doit permettre l'édition de statistiques. Il me faut compter les occurences de chacun des motifs dans les décisions prises.

    Pour les solutions proposés :
    • la première ne donne pas de résultat différent
    • la seconde n'est pas une solution (d'après mon problème)


    Petite précision : je travaille sous Access 2002

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 56
    Par défaut Re: [débutant] Jointure + Count
    Citation Envoyé par MashiMaro
    Euh petite correction d'orthographe : libelle_motif

    Petit conseil : évite les accents dans les noms de colonnes.
    Les champs sont donnés à titre d'exemple, je ne travaille pas sur des champs nommés ainsi. C'est pour une question de clareté que je francise les noms des tables et des champs.

    Et puisque j'en suis à la rubrique des conseils, je viens de lire
    http://www.developpez.net/forums/viewtopic.php?t=32668
    et j'essairai de m'y tenir pour la prochaine fois.
    D'ailleurs, me conseillez-vous de placer ma question dans le forum Access ou de rester ici?

  6. #6
    Invité de passage
    Inscrit en
    Octobre 2003
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Octobre 2003
    Messages : 1
    Par défaut Re: [débutant] Jointure + Count
    Citation Envoyé par vttman
    Citation Envoyé par Yann21
    Bonjour, il se pose à moi un problème sur une réquête impliquant une jointure et un count. Voici, de manière simplifiée, les deux tables concernées :

    motif(code_motif, libélé_motif)

    décision(num_demande, code_décision, code_motif)

    Le but de la requête est d'afficher le nombre d'occurences de chaque motif à partir de l'ensemble des décisions. En clair :

    motif_1 -> 12
    motif_2 -> 3
    motif_3 -> 0
    ...
    motif_10 -> 23

    Voici ma requête à l'heure actuelle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT motif.libélé_motif, Count(motif.code_motif) AS compteDecode_motif
    FROM motif INNER JOIN décision ON motif.code_motif = décision.code_motif
    WHERE (décision.code_décision="0")
    GROUP BY motif.libc_motif;
    Le problème est quelle ne m'affiche pas le motif_3 puisqu'aucune occurence n'est trouvée.

    Merci d'avance pour vos solutions.

    Dans décision ?

    Si oui remplacer
    INNER JOIN par LEFT JOIN ...
    S'il n'y a pas de décision pour un des motifs =>
    décision.code_décision sera à NULL pour le motif considéré

    Ce qui nous donne ...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT motif.libélé_motif, Count(motif.code_motif) AS compteDecode_motif
    FROM motif LEFT JOIN décision ON motif.code_motif = décision.code_motif
    WHERE (décision.code_décision="0") or 
    (décision.code_décision is null)
    GROUP BY motif.libc_motif;
    A tester ...
    tu peut faire ça :
    SELECT motif.libélé_motif, Count(motif.code_motif) AS compteDecode_motif
    FROM motif INNER JOIN décision ON motif.code_motif = décision.code_motif
    WHERE (décision.code_décision="0")
    GROUP BY motif.libc_motif;

    UNION

    SELECT motif.libélé_motif, 0 AS compteDecode_motif
    FROM motif
    WHERE not exists
    (select * from décision where décision.code_motif=motif.code_motif);

  7. #7
    Membre averti
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    56
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 56
    Par défaut
    C'est exactement celà. Merci beaucoup.

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

Discussions similaires

  1. [Débutant] Jointures hibernate
    Par mouaa dans le forum Hibernate
    Réponses: 20
    Dernier message: 05/11/2008, 21h44
  2. (débutant) Requête COUNT
    Par winx dans le forum Langage SQL
    Réponses: 2
    Dernier message: 27/04/2008, 11h10
  3. [débutant] jointure sur resultat "temporaire" (mal dit :/ )
    Par boolzor dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 22/06/2007, 12h50
  4. Jointure / Count
    Par altecad dans le forum Requêtes
    Réponses: 1
    Dernier message: 16/05/2007, 09h30
  5. [SQL Server] [Débutant] Jointure de plusieurs vues
    Par f.le.chat dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 22/05/2006, 10h13

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