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 INNER JOIN


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club Avatar de toinexplore
    Homme Profil pro
    Etudiant/Passionné SQL-C
    Inscrit en
    Décembre 2017
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Etudiant/Passionné SQL-C
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2017
    Messages : 38
    Points : 32
    Points
    32
    Par défaut Requête INNER JOIN
    Bonjour à tous, je découvre que depuis tout récemment le langage SQL

    Dans l'un de mes exercices, on me demande d'afficher le nom et le grade des enseignant de français.
    On a le MLD suivant (j'en intègre ici que la partie utile pour la requête demandée dans l'exercice)

    MATIERE (NumMat,NomMat,NumEns)
    ENSEIGNANT(NumEns,NomEns,Grade,Anciennete)

    Question : Afficher le nom et le grade des enseignants de Français

    Voici ma requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT Grade
    FROM ENSEIGNANT AS ENS
    INNER JOIN MATIERE AS MAT
    ON NumEns.ENS=NumEns.MAT
    WHERE NomMat='Français'

    Est-ce juste ?

    Merci d'avance !!

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 136
    Points : 38 910
    Points
    38 910
    Billets dans le blog
    9
    Par défaut
    Bonjour,

    La syntaxe de cette requete est invalide, il faut citer nom_table.nom_colonne et non l'inverse comme vous l'avez fait

    De plus, on vous demande le nom et le grade des enseignants, pas seulement le grade

    Enfin, pour faciliter la relecture de la requête, il est préférable de préfixer par des alias toutes les colonnes (SELECT, JOIN, WHERE...)

    Ce qui donne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT NomEns
         , Grade
    FROM ENSEIGNANT AS ENS
    INNER JOIN MATIERE AS MAT
       ON ENS.NumEns=MAT.NumEns
    WHERE MAT.NomMat='Français'
    Edit : pour vos requêtes, utilisez la balise code (symbole # dans la barre d'outils)

  3. #3
    Nouveau membre du Club Avatar de toinexplore
    Homme Profil pro
    Etudiant/Passionné SQL-C
    Inscrit en
    Décembre 2017
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Etudiant/Passionné SQL-C
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2017
    Messages : 38
    Points : 32
    Points
    32
    Par défaut
    Merci beaucoup

    Donc si j'ai bien compris, lorsque l'on "fait" l'alias MAT.NomMat, cela correspond à NomMat ?

    C'est dans le cas où l'on utilise INNER JOIN que l'on continue avec cette syntaxe d'alias pour plus de lisibilité et de clarté ?

    Imaginons maintenant que je veuille Afficher le nom et le grade des enseignants d'informatique dont l'ancienneté est au moins 2 ans :

    j'ai fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT NomEns,Grade
    FROM ENSEIGNANT AS ENS 
    INNER JOIN MATIERE AS MAT
    ON MAT.NumEns=ENS.NumENS 
    WHERE MAT.NomMat = 'Informatique', ENS.Anciennete>=2

  4. #4
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 136
    Points : 38 910
    Points
    38 910
    Billets dans le blog
    9
    Par défaut
    L'alias est un surnom que l'on donne à une table, une vue, ou une colonne

    Par exemple dans la requête SELECT T1.Col1 as C1 from MaTable as T1 T1 est l'alias donné à la table MaTable et C1 l'alias donné à la colonne Col1
    L'utilisation d'alias est obligatoire dans le cas d'une auto jointure, c'est à dire d'une table ou vue avec elle même
    Elle n'est pas obligatoire, mais recommandée en cas de jointure entre des tables ou vues différentes, ça évite de manipuler des noms parfois à rallonge de tables ou vue et facilite la compréhension en identifiant l'origine des données (on sait que telle colonne vient de telle table/vue)

  5. #5
    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
    Citation Envoyé par toinexplore Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    WHERE MAT.NomMat = 'Informatique', ENS.Anciennete>=2
    Dans la Clause WHERE, les différentes conditions sont à séparer par des connecteurs logiques : AND, OR

  6. #6
    Nouveau membre du Club Avatar de toinexplore
    Homme Profil pro
    Etudiant/Passionné SQL-C
    Inscrit en
    Décembre 2017
    Messages
    38
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Etudiant/Passionné SQL-C
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2017
    Messages : 38
    Points : 32
    Points
    32
    Par défaut
    Bonjour,

    Merci beaucoup pour vos réponses.

    Je n'ai pas encore vraiment bien assimilé INNER JOIN mais je pense que ça va finir par rentrer à force de tentatives.

    Merci pour ces explications claires, j'ai mis du temps pour comprendre que WHERE s'accompagne de AND ou OR mais du coup j'y retourne en esperant que cette fois-ci ma requête fonctionne .

Discussions similaires

  1. Requête + inner join+ update
    Par zorro13 dans le forum SQL
    Réponses: 4
    Dernier message: 28/10/2011, 16h26
  2. Requête INNER JOIN ?
    Par Souri84 dans le forum Requêtes
    Réponses: 3
    Dernier message: 21/05/2010, 15h39
  3. Problème requête INNER JOIN
    Par punisher999 dans le forum Requêtes
    Réponses: 1
    Dernier message: 04/12/2009, 09h51
  4. requête INNER JOIN
    Par Jasmine80 dans le forum Requêtes
    Réponses: 7
    Dernier message: 06/03/2009, 11h00
  5. Réponses: 6
    Dernier message: 26/09/2008, 10h04

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