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 :

Problème avec une requête


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Profil pro
    Enseignant
    Inscrit en
    Juillet 2004
    Messages
    128
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Juillet 2004
    Messages : 128
    Points : 119
    Points
    119
    Par défaut Problème avec une requête
    Bonjour,

    Je travaille actuellement avec deux tables

    Exercice : IdExercice, evaluation, ordre, commentaire
    Acquisition : IdAcquisition, eleve, exercice, niveau.

    Il existe une jointure entre les deux tables Acquisition.exercice = Exercice.IdExercice.

    J'essaie de récupérer pour un élève donné (donc en A.eleve) les résultats sur l'ensemble des exercices sachant que certains exercices ne sont pas présents dans la table Acquisition. Je n'arrive pas à récupérer l'ensemble. Je n'arrive à récupérer que les exercices renseignés.

    Comment puis-je faire ?

    Un exemple sera peut-être mieux:
    Exercice : (1,1,1,'exercice1')
    (2,1,2,'exercice2')
    (3,1,3,'exercice3')
    Acquisition : (1,eleve1,1,TB)
    (2,eleve1,3,B)
    (3,eleve2,1,B)

    J'aimerais obtenir comme résultat en (IdExercice,IdAcquisition,eleve,niveau)
    (1,1,eleve1,TB)
    (2,null,null,null)
    (3,2,eleve1,B)

    J'espère que j'ai été assez clair.

    Merci d'avance

  2. #2
    Membre expérimenté Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Points : 1 738
    Points
    1 738
    Par défaut
    utilisez une jointure externe.

    Bon courage

  3. #3
    Membre régulier
    Profil pro
    Enseignant
    Inscrit en
    Juillet 2004
    Messages
    128
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Juillet 2004
    Messages : 128
    Points : 119
    Points
    119
    Par défaut
    J'ai bien essayé mais ça ne marche pas.

  4. #4
    Membre expérimenté Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Points : 1 738
    Points
    1 738
    Par défaut
    Comment avez vous ecrit la requete qui ne fonctionne pas ?

  5. #5
    Membre régulier
    Profil pro
    Enseignant
    Inscrit en
    Juillet 2004
    Messages
    128
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Juillet 2004
    Messages : 128
    Points : 119
    Points
    119
    Par défaut
    Finalement j'ai trouvé une solution.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT E.IdExercice, E.Commentaire, El.element, T.niveau 
    from exercices E 
    inner join elements El ON E.element=El.Idelements 
    left outer join (select * from acquisitions where eleve='eleve1') T 
    ON T.exercice=E.IdExercice where E.evaluation=1 order by E.ordre
    Au départ je n'utilisais pas de requête et je plaçais mon where eleve='eleve1' avec l'autre condition sur l'évaluation.

  6. #6
    Membre expérimenté Avatar de Yanika_bzh
    Homme Profil pro
    Responsable Applicatif et R&D
    Inscrit en
    Février 2006
    Messages
    1 144
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Responsable Applicatif et R&D
    Secteur : Finance

    Informations forums :
    Inscription : Février 2006
    Messages : 1 144
    Points : 1 738
    Points
    1 738
    Par défaut
    Une table elements est apparue ...

    sinon vous aviez :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    SELECT 
          a.IdExercice, b.IdAcquisition, b.eleve, b.niveau
      FROM 
          exercice a LEFT OUTER JOIN acquisition b ON (a.IdExercice = b.exercice)
     WHERE 
          eleve = 'eleve1' OR eleve IS NULL

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

Discussions similaires

  1. [TADOQuery] Problème avec une requête
    Par yannba dans le forum Bases de données
    Réponses: 2
    Dernier message: 20/01/2006, 13h51
  2. Problème avec une requête
    Par demonark dans le forum Langage SQL
    Réponses: 3
    Dernier message: 19/09/2005, 05h35
  3. Problème avec une requête
    Par ringostarr dans le forum Langage SQL
    Réponses: 5
    Dernier message: 19/04/2005, 20h34
  4. Problème avec une requête
    Par snoopy69 dans le forum Débuter
    Réponses: 2
    Dernier message: 20/01/2005, 12h39
  5. problème avec une requête imbriquée
    Par jaimepasteevy dans le forum Langage SQL
    Réponses: 13
    Dernier message: 05/12/2003, 10h29

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