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 :

Exercice (requête )


Sujet :

Langage SQL

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Femme Profil pro
    Étudiant
    Inscrit en
    Décembre 2019
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2019
    Messages : 40
    Par défaut Exercice (requête )
    Bonsoir, j'ai 5 tables avec 4 requêtes a faire :

    Contrat(NumContrat,DateDebutLoc ,DateFinLoc,RefAppart,NumClient)
    Client(NumClient,nom,prenom,adresse)
    Appartement(RefAppart,adresse,nbChambre,superficie,montant-Charges)
    Réparation(NumRépération,typeRéparartion)
    Appartement-Réparartion(RefAppart,NumRépération,dateTravaux,montantTravaux)

    1) Cout total des travaux pour chaque appartement désigné par sa référence et adresse
    2)Nom et prénom des client ayant loué le plus d'appartements
    3)Adresse des départements qui n'ont pas fait l'object de réparation
    4) Adresse des appartements composé de 3 chambres et qui ont été le plus loués

    J'ai fais ça mais je suis pas très sur si quelqu'un pourrait m'aider s'il vous plait merci d'avance
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT SUM(montantTravaux) as som ,refAppart,adresse WHERE Appartement-Réparation.RefAppart=Appartement.RefAppart  GROUP BY refAppart ,adresse
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT nom,prenom, FROM Client , Contrat  WHERE Contrat.NumClient=Client.NumClient AND RefAppart >= (SELECT COUNT(RefAppart) FROM Appartement)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT adresse FROM Appartement,Appartement-Réparation WHERE Appartement.RefAppart=Appartement-Réparation.RefAppart AND RefAppart NOT IN (SELECT NumRéparation FROM Appartement-Réparation)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SELECT adresse , COUNT(NbChambre)=3 FROM Contrat WHERE RefAppart >= ALL( SELECT MAX(DateFinLoc - DateDebutLoc ) FROM Client )

  2. #2
    Expert confirmé
    Homme Profil pro
    Responsable Données
    Inscrit en
    Janvier 2009
    Messages
    5 462
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable Données

    Informations forums :
    Inscription : Janvier 2009
    Messages : 5 462
    Par défaut
    bonjour,
    Comme il s'agit d'un exercice, je vais juste te donner des indications.
    Alors dans l'ordre:
    1: il manque une clause dans la requête
    2: tu compares la référence d'un appartement avec un nombre d'appartement. Ca ne peux pas fonctionner.
    3: Vu la jointure entre appartement et appartement-reparation, la requête ne peut renvoyer que les appartement ayant fait l'objet d'une réparation. Mais avec le sous-requête en plus, elle ne renvoie rien du tout.
    4: Tu mets count(nbChambre) = 3 dans le SELECT. Quelle est la clause de la requête qui définie les colonnes à renvoyer, et celle qui filtre la requête ? De plus, tu compares un nombre de jours et une référence d'appartement, tu utilises des colonnes d'une table qui ne sont pas dans la clause FROM…

    Sinon sur le fond, il faut expliquer à ton prof que les jointures s'écrivent avec un JOIN depuis le siècle dernier…

    Tatayo.

  3. #3
    Membre émérite
    Profil pro
    Inscrit en
    Octobre 2002
    Messages
    956
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2002
    Messages : 956
    Par défaut
    Bonjour,
    De façon générale les jointures s'écrivent avec un inner join, ou left outer join et pas dans le where.
    Concernant la 3 ème requete. Le libellé doit être erroné, car il n'est question nulle par de département, on va supposer qu'il s'agit d'appartement.
    La requête que tu proposes ne peut rien renvoyer, car tu fais une jointure entre les appartements et les appartement-reparation , le resultat est les appartements ayant subi des réparation et après tu rajoutes un critère Not in pour supprimer les appartements ayant eu des réparations. Tu n'étais pas loin, il suffit de supprimer la jointure dans la requête principale

    Pour la quatrième question, je n'arrive pas à comprendre ce que tu as voulu faire. D'abord il faudrait savoir qu'est-ce que veux dire le plus loué. Le nombre le plus élevé de location ou la durée la plus longue de location ?

    Cordialement
    Soazig

Discussions similaires

  1. [AC-2016] Exercice Requêtes
    Par Céline.P dans le forum Requêtes et SQL.
    Réponses: 7
    Dernier message: 16/04/2019, 18h01
  2. Exercices requêtes SQL (je coince)
    Par Celsoufre dans le forum Langage SQL
    Réponses: 2
    Dernier message: 05/02/2014, 11h22
  3. Exercice requête
    Par lobotoFix dans le forum Requêtes
    Réponses: 2
    Dernier message: 15/03/2013, 09h51
  4. besoin d'aide pour un exercice (requêtes sql)
    Par stabii dans le forum Langage SQL
    Réponses: 15
    Dernier message: 30/01/2011, 00h00
  5. [Exercice] Aide sur requête
    Par Dobyan08 dans le forum Langage SQL
    Réponses: 6
    Dernier message: 09/02/2006, 15h47

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