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êtes SQL d'un sujet de concours ITRF


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2008
    Messages
    207
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2008
    Messages : 207
    Points : 114
    Points
    114
    Par défaut requêtes SQL d'un sujet de concours ITRF
    Bonjour,

    je prépare un concours ITRF et j'aimerais savoir si vous êtes d'accord avec mes requêtes.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Le schéma relationnel suivant représente la gestion simplifiée de bandes dessinées (BD) :
     
    BD (NumBD, NomAlbum, NBPages, EditeurNumDessinateur, NumScénariste)
    Auteur (NumAuteur, Prénom, Nom, Nationalité)
    Magasin (NumMag, NomMag, Adresse, Téléphone, NomResponsable)
    BDDansMagasin (NumBD, NumMagasin, NbBDDispo, PrixVente)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    En langage SQL :
    1. Donnez les noms des auteurs de bande dessinée (en tant que scénariste ou dessinateur) qui sont responsables d’un magasin.
     
    2. Donnez les noms des magasins dont le responsable est aussi un des auteurs d’une des BD disponibles dans ce même magasin.
     
    3. Donnez la liste des titres d’albums de BD disponibles, regroupés par magasin.
    Voici mes propositions, mais j'ai parfois des doutes:

    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
    19
    20
    1) SELECT Nom
    FROM AUTEUR a, MAGASIN m
    WHERE a.Nom = m.NomResponsable;
     
    2) SELECT m.NomMag
    FROM BD, AUTEUR a, BDDANSMAGASIN bdmag, MAGASIN m
    WHERE m.NomResponsable = a.Nom
    AND (a.NumAuteur = BD.EditeurNumDessinateur
    OR a.NumAuteur = BD.NumScenariste)
    AND m.NumMag = bdmag.NumMagasin
    AND BD.NumBD = bdmag.NumBD
    AND NbBDDispo >0;
    (HAVING?)
     
    3) SELECT BD.NomAlbum
    FROM BD, MAGASIN m, BDDANSMAGASIN bdm
    WHERE BD.NumBD = m.NumBD
    AND m.NumMag = bdmag.NumMagasin
    AND NbBDDispo >0
    ORDER BY m.NomMag;
    Qu'en pensez-vous?
    Etes-vous d'accord?

    Merci par avance,
    Johnny

  2. #2
    Expert éminent sénior
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 812
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 812
    Points : 34 084
    Points
    34 084
    Billets dans le blog
    14
    Par défaut
    Sans aller plus loin, une remarque de base :
    La syntaxe normalisée depuis 1992 pour les jointures est la suivante :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    FROM tableA
    JOIN tableB ON condition de jointure
    Pour plus d'infos, voir : http://sqlpro.developpez.com/cours/sqlaz/jointures/
    et notamment le chapitre III.

    Bonne lecture.

    Autre chose aussi : HAVING est un WHERE qui opère sur le résultat d'une opération de regroupement (SUM, AVG, COUNT...).

  3. #3
    Membre régulier
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2008
    Messages
    207
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2008
    Messages : 207
    Points : 114
    Points
    114
    Par défaut
    lol, cette notation vient du prof du Cnam (IDF)! Je vais me mettre à jour.

  4. #4
    Expert éminent sénior
    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 812
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 812
    Points : 34 084
    Points
    34 084
    Billets dans le blog
    14
    Par défaut
    Comment s'appelle ce prof ?
    Au cas où ce serait mon examinateur de soutenance de mémoire... faut pas que je le froisse...

  5. #5
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 933
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 933
    Points : 51 748
    Points
    51 748
    Billets dans le blog
    6
    Par défaut
    La première est déjà fausse. Relisez le texte :

    1. Donnez les noms des auteurs de bande dessinée (en tant que scénariste ou dessinateur) qui sont responsables d’un magasin.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT Nom
    FROM   Auteur AS A
           INNER JOIN Magasin AS M
                 ON A.Nom = M.NomResponsable
           INNER JOIN BD 
                 ON (A.NumAuteur = EditeurNumDessinateur 
                     OR A.NumAuteur  = NumScénariste)
    A +

  6. #6
    Membre régulier
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2008
    Messages
    207
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2008
    Messages : 207
    Points : 114
    Points
    114
    Par défaut
    Citation Envoyé par CinePhil Voir le message
    Comment s'appelle ce prof ?
    Au cas où ce serait mon examinateur de soutenance de mémoire... faut pas que je le froisse...
    Benguigui.

    Exemple de corrigé qu'il nous avait donné:

    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
    SELECT DISTINCT M.NOM
    FROM CLASSE C, PERSONNE M,
    ENFANT E, PERSONNE R
    WHERE C.MAITRE = M.NOM
    AND E.NOMEC = C.NOMEC
    AND E.NCL = C.NCL
    AND E.NOMP = R.NOM
    AND M.ADR = R.ADR
     
    ou (imbriqué) :
    SELECT C.MAITRE
    FROM CLASSE C, PERSONNE P
    WHERE C.MAITRE = P.NOM AND P.ADR IN (SELECT P.ADR
    FROM PERSONNE P, ENFANT E
    WHERE P.NOM = E.NOMP AND
    E.NOMEC = C.NOMEC AND
    E.NCL = C.NCL)

  7. #7
    Membre régulier
    Homme Profil pro
    Développeur Web
    Inscrit en
    Février 2008
    Messages
    207
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2008
    Messages : 207
    Points : 114
    Points
    114
    Par défaut
    Citation Envoyé par SQLpro Voir le message
    La première est déjà fausse. Relisez le texte :

    1. Donnez les noms des auteurs de bande dessinée (en tant que scénariste ou dessinateur) qui sont responsables d’un magasin.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SELECT Nom
    FROM   Auteur AS A
           INNER JOIN Magasin AS M
                 ON A.Nom = M.NomResponsable
           INNER JOIN BD 
                 ON (A.NumAuteur = EditeurNumDessinateur 
                     OR A.NumAuteur  = NumScénariste)
    A +
    Je me disais que ce n'était pas la peine de soumettre le SGBD à cette condition, car les auteurs étaient soit dessinateurs, soit scenaristes, et donc que rajouter cette condition n'éliminerait pas certains tuples.

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

Discussions similaires

  1. Requête SQL
    Par Leludo dans le forum Langage SQL
    Réponses: 3
    Dernier message: 12/07/2024, 16h41
  2. Réponses: 6
    Dernier message: 21/03/2009, 18h34
  3. [ DB2 ] [ AS400] requête sql
    Par zinaif dans le forum DB2
    Réponses: 6
    Dernier message: 23/08/2008, 20h42
  4. Utilisation de MAX dans une requête SQL
    Par Evil onE dans le forum Langage SQL
    Réponses: 7
    Dernier message: 15/06/2004, 19h38

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