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

Requêtes MySQL Discussion :

2 select différents / conditions différentes dans même requête


Sujet :

Requêtes MySQL

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2009
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 39
    Points : 13
    Points
    13
    Par défaut 2 select différents / conditions différentes dans même requête
    Bonjour,

    Pour m'exercer, je cherche à faire une base qui répertorie les notes d'élèves à des devoirs, dans la base il y a ces 2 tables :
    devoirs : id | titre
    et
    notes : id | élève | note | id_devoir

    et je cherche a faire une seule requête pour afficher un tableau avec :
    titre du devoir | moyenne tous les élèves à ce devoir | note personnel de l'élève connecté

    pour l'instant j'ai fait 2 requêtes différentes pour obtenir, soit la moyenne de tous les élèves pour chaque devoir, soit la note d'1 seul élève pour chaque devoir :
    moyenne de tous les élèves :
    SELECT AVG(notes.note) as moyenne, devoirs.titre FROM devoirs, notes WHERE notes.id_devoir = devoirs.id GROUP BY devoirs.id ORDER BY devoir.id

    note personnel :
    SELECT notes.note, devoir.titre FROM notes, devoirs WHERE notes.eleve ='".$eleve."' AND notes.id_devoir = devoir.id ORDER BY notes.id_devoir

    j'ai fait des essais avec UNION, plusieurs SELECT dans la même requête... etc, mais je ne trouve pas la solution

    Savez vous comment faire ?

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    Bonjour,

    Utilisez une sous-requête http://sqlpro.developpez.com/cours/sqlaz/sousrequetes/

  3. #3
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT 
        devoirs.titre,
        AVG(notes.note) as moyenne,
        MAX(CASE WHEN notes.eleve ='".$eleve."'  THEN notes.note END ) AS NoteEleve
    FROM devoirs
    INNER JOIN notes 
      ON  notes.id_devoir = devoirs.id
    GROUP BY devoirs.titre
    ORDER BY devoir.id

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Février 2009
    Messages
    39
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 39
    Points : 13
    Points
    13
    Par défaut
    merci beaucoup à tous les 2 !

    j'ai essayé de chercher avec le lien de punkoff, but there where no futur for me..., trop compliqué...

    la requête de aieeeuuuuu marche très bien

    maintenant il faut que je bosse encore pour trouver tout seul ce type de requête, mais ya du boulot...

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 26/03/2014, 17h18
  2. Double somme dans même requête
    Par MickSou dans le forum Langage SQL
    Réponses: 4
    Dernier message: 17/11/2011, 14h14
  3. Réponses: 10
    Dernier message: 26/03/2008, 15h00
  4. Somme sur conditions imbriquée dans une requête
    Par aleximan dans le forum Requêtes et SQL.
    Réponses: 8
    Dernier message: 25/01/2008, 18h05
  5. CompteDe + % dans même requête
    Par Nessie37 dans le forum Requêtes et SQL.
    Réponses: 21
    Dernier message: 05/11/2007, 18h15

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