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

Bases de données Delphi Discussion :

[SQL Server] Requête SQL avec jointure 3 tables


Sujet :

Bases de données Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2022
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mai 2022
    Messages : 18
    Par défaut [SQL Server] Requête SQL avec jointure 3 tables
    Je suis en train de créer une application (gestion Emprunte des Livre d’un Bibliothèque (ajout, supprimer, Modifier, Enregistre ...)), tout en utilisant ADOConnection, ADOTable et DataSource et ADOQuery pour les requêtes.

    La base de données est créée avec SQL Server :
    TABLE Emprunteur (N_Empr, Nom_Empr, Prenom_Empr)
    TABLE Livre ( N_Ser_Liv, Code_Liv, Titre_Liv, Auteur_Liv, Code_Cop_Liv, Nob_Exemp_Liv, # N_Spec)
    TABLE Auteur (N_Auteur, Nom_Pren_Auteur, Nation_Auteur)
    TABLE Bronche (N_Bron, Nom_Bron)
    TABLE Spécialité (N_Spec,Nom_Spec, # N_Bron)
    TABLE Punition (N_Punition, Guide_Punition,Type_Punition, Date_Punition, Duree_Punition)
    TABLE Convocation (N_Conv, Raison_Conv, Date_Conv, Date_Comp_Conv, Heur_Comp_Conv, Annee_Scol, #N_Empr, #N_Punition)
    TABLE Ecrivez (N_Ser_Liv, N_Auteur)
    TABLE Emprunte (N_Empr, N_Ser_Liv, Date_Liv_Prete, Date_Liv_Ren, Duree_Prete)
    TABLE Mouvement_Livre ( N_Ser_Liv, Code_Liv, Titre_Liv, Auteur_Liv, Code_Cop_Liv, Nob_Exemp_Liv, N_Spec)
    TABLE Mouvement_Emprunte (N_Empr, N_Ser_Liv, Date_Liv_Prete, Date_Liv_Ren, Duree_Prete)
    OB : La Table Mouvement_Emprunte ET La Table Mouvement_Livre se sant des tables identique des table (Emprunte et Livre) pour Sauvegarder une copier d’historique appris chaque suppression au modification
    Donc
    Je cherche faire Des requêtes qui permettront d’imprimer des listes Dans DELPHI :

    1. Liste Livres Emprunte (Historique) : Avec affichage du (Nom, Prénom, Titre Livre)
    2. Liste Livres en cours d’Emprunté : Avec affichage du (Nom, Prénom, Titre Livre)
    3. Liste Livres Non Emprunté : Avec affichage du (Nom, Prénom, Titre Livre)
    4. Liste Livres Non Rendu : Avec affichage du (Nom, Prénom, Titre Livre)
    5. Liste Livres Retard Non Rendu: Avec affichage du (Nom, Prénom, Titre Livre)
    6. Liste Emprunteur Puni : Avec affichage du (Nom, Prénom)

    J’ai essayé quelques requêtes de INNER JOIN mais rien ne s’affiche dans mon DBGrid.

  2. #2
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 596
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 596
    Billets dans le blog
    65
    Par défaut
    Bonjour, c'est plus une question SQL que Delphi.
    Il y a des forums spécifiques pour ça https://www.developpez.net/forums/f3...s/langage-sql/, https://www.developpez.net/forums/f4...ms-sql-server/

    une remarque d'abord il eut été bon de nous montrer vos quelques essais SQL

    Note : je ne suis pas très à l'aise avec SQL Server donc il y a peut-être des erreurs SQL


    1 -Liste Livres Empruntés
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT E.Nom_Empr Nom, E.Prenom_Empr Prenom,L.Titre_Liv  Titre 
    FROM Mouvement_Emprunte M 
       JOIN  Emprunteur E ON E.N_Empr=M.N_Empr , Nom_Empr, Prenom_Empr)
       JOIN  Livre L ON L.N_Ser_Liv=M.N_Ser_LIV

    2-Liste Livres en cours d’Emprunt
    c'est le même SQL que 1, avec une clause WHERE sur Date_Liv_Ren, à vérifier cette colonne doit permettre le null
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT E.Nom_Empr Nom, E.Prenom_Empr Prenom,L.Titre_Liv  Titre 
    FROM Mouvement_Emprunte M 
       JOIN  Emprunteur E ON E.N_Empr=M.N_Empr , Nom_Empr, Prenom_Empr)
       JOIN  Livre L ON L.N_Ser_Liv=M.N_Ser_LIV   
    WHERE M. Date_Liv_Ren IS NULL

    3 Liste Livres Non Emprunté : Avec affichage du (Nom, Prénom, Titre Livre)
    Comment peut-on afficher des noms d'emprunteur si les livres ne sont pas empruntés ?

    4 Liste Livres Non Rendu
    c'est le même SQL que 2 , avec une clause possible sur Date_Liv_Prete (indiquée en commentaire --)
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT E.Nom_Empr Nom, E.Prenom_Empr Prenom,L.Titre_Liv  Titre 
    FROM Mouvement_Emprunte M 
       JOIN  Emprunteur E ON E.N_Empr=M.N_Empr , Nom_Empr, Prenom_Empr)
       JOIN  Livre L ON L.N_Ser_Liv=M.N_Ser_LIV   
    WHERE M. Date_Liv_Ren IS NULL -- AND  DATEADD(days, M.Duree_Prete,M. Date_Liv__Prete)<=GET_DATE()

    5 Liste Livres Retard Non Rendu:
    idem 4, il suffit de changer la clause WHERE
    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    SELECT E.Nom_Empr Nom, E.Prenom_Empr Prenom,L.Titre_Liv  Titre 
    FROM Mouvement_Emprunte M 
       JOIN  Emprunteur E ON E.N_Empr=M.N_Empr , Nom_Empr, Prenom_Empr)
       JOIN  Livre L ON L.N_Ser_Liv=M.N_Ser_LIV   
    WHERE M. Date_Liv_Ren IS NULL AND  DATEADD(days, M.Duree_Prete,M. Date_Liv__Prete)>GET_DATE()

    6 Liste Emprunteur Puni
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SELECT  E.Nom_Empr, E.Prenom_Empr  
    FROM Convocation  C 
       LEFT JOIN  Emprunteur E ON E.N_Empr=C.N_Empr
       LEFT JOIN  Punition P ON P.N_Punition=C.N_Punition
    WHERE DATEADD(days, P. Duree_Punition,P.Date_Punition)<Get_date()
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    SELECT  E.Nom_Empr, E.Prenom_Empr,COUNT(1) Nombre_punitions,Max(DATEADD(days, P. Duree_Punition,P.Date_Punition) fin_punition  
    FROM Convocation  C 
       LEFT JOIN  Emprunteur E ON E.N_Empr=C.N_Empr
       LEFT JOIN  Punition P ON P.N_Punition=C.N_Punition
    WHERE DATEADD(days, P. Duree_Punition,P.Date_Punition)<Get_date()
    GROUP BY E.Nom_Empr, E.Prenom_Empr

    OB : La Table Mouvement_Emprunte ET La Table Mouvement_Livre sont des tables identique
    pas vraiment, et il manque la notion d'emprunteur dans la seconde

  3. #3
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 086
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 14 086
    Par défaut
    Est-ce un devoir scolaire ?
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  4. #4
    Rédacteur/Modérateur

    Avatar de SergioMaster
    Homme Profil pro
    Développeur informatique retraité
    Inscrit en
    Janvier 2007
    Messages
    15 596
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2007
    Messages : 15 596
    Billets dans le blog
    65
    Par défaut
    Citation Envoyé par ShaiLeTroll Voir le message
    Est-ce un devoir scolaire ?
    J'ai eu aussi le doute, mais un travail scolaire avec une structure de BDD comme ça je n'y crois pas trop

  5. #5
    Membre actif
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2022
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Algérie

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mai 2022
    Messages : 18
    Par défaut Non Non
    Citation Envoyé par ShaiLeTroll Voir le message
    Est-ce un devoir scolaire ?

Discussions similaires

  1. Requête SQL avec jointure sur table existant ou non
    Par Amateur_Unix dans le forum SQL
    Réponses: 4
    Dernier message: 01/10/2021, 15h29
  2. [8i] Requête SQL avec jointure sur la même table
    Par masterdash dans le forum SQL
    Réponses: 13
    Dernier message: 10/03/2016, 20h56
  3. Requête sql avec jointure et table vide (ou tuple nulle)
    Par Aenur56 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 29/04/2010, 14h10
  4. Requête SQL avec jointure sur trois tables
    Par pit2121 dans le forum SQL
    Réponses: 0
    Dernier message: 19/05/2008, 20h24
  5. [MySQL] Erreur SQL 1064 : Requête imbriquée avec jointure !
    Par patchankito dans le forum Langage SQL
    Réponses: 5
    Dernier message: 31/01/2006, 10h37

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