Modèle Conceptuel de Données (MCD) Gestion d'une Bibliothèque
0,5 Un inscrit peut emprunté, lorsqu'il est enregistré dans la base de données de
zéro à cinq livres. 0,n Un jour donné il peut y avoir aucun ou plusieurs ...
Part of the document
Modèle Conceptuel de Données (MCD) Gestion d'une Bibliothèque
[pic]
Cardinalités
CIF Fournisseur - Livre :
0,n Un fournisseur enregistré dans la base de donné peut fournir 0 ou
plusieurs livres
1,1 Un livre est fournit par un et un seul fournisseur
Emprunter Livre - Inscrit - Date:
0,n Un livre peut être emprunté par aucun utilisateur ou être emprunté
plusieurs fois
0,5 Un inscrit peut emprunté, lorsqu'il est enregistré dans la base de
données de zéro à cinq livres
0,n Un jour donné il peut y avoir aucun ou plusieurs emprunts
Modèle Logique de Données (MLD)
Entités (on reprend les attributs et souligne les identifiants)
Fournisseur (NomFour, AdrFour, VilleFour, CPFour, Type)
Livre (NumLivre, TitreLivre, Auteur(s), Editeur, NbPage, Prix,
NomFour)
Inscrit (NumInscr, NomInscr,PrenomInscr,AdrInscr,VillInscr, CPInscr)
Association (on reprend l'attribut de l'association et on ajoute les
identifiants des entités associées)
Emprunter (NumLivre, DateEmpr, NumInscr, DateRetEff)
Paramètres
Durée d'emprunt 30 jours max
Pénalités 0.15 E par jour de retard
Requêtes
. Paramètre1 : Livre(s) non-acheté(s) directement à leur éditeur
SELECT DISTINCT Emprunter.NumInscr, Inscrit.NomInscr, Inscrit.PrenInscr,
Emprunter.Numlivre, Livre.TitreLivre, Emprunter.DateEmpr+30 AS [Retour
Attendu], (Date()-[Retour Attendu])*0.15 AS Pénalité
FROM Emprunter, Livre, Inscrit
WHERE Emprunter.DateRetEff Is Null And Emprunter.NumInscr=Inscrit.NumInscr
And Emprunter.NumLivre=Livre.NumLivre;
. Requête1 : Livre(s) non-acheté(s) directement à leur éditeur
SELECT Livre.TitreLivre AS [Livres non-achetés à leur éditeur]
FROM Livre
WHERE (((Livre.Editeur)([Livre].[Nomfour])));
=> Affiche dans une table les livres qui n'ont pas été achetés directement
à l'éditeur mais par l'intermédiaire d'un libraire.
. Requête2 : Couple(s) Emprunteur, titre du livre emprunté
SELECT DISTINCT Inscrit.NomInscr AS [Nom Emprunteur(s)], Livre.TitreLivre
AS [Livre(s) Emprunté(s)], Inscrit.PrenInscr AS [Prénom Emprunteur(s)]
FROM Inscrit, Livre, Emprunter
WHERE (((Inscrit.NumInscr)=[Emprunter].[NumInscr]) AND
((Livre.NumLivre)=[Emprunter].[Numlivre]))
ORDER BY Inscrit.NomInscr, Inscrit.PrenInscr;
=> Affiche une table dans laquelle sont listés tous les livres empruntés et
leurs emprunteurs.
. Requête3 : Nbre d'emprunt(s) d'un livre par un même utilisateur
SELECT DISTINCT Inscrit.NomInscr AS [Nom Emprunteur(s)], Inscrit.PrenInscr
AS [Prénom Emprunteur(s)], Livre.TitreLivre AS [Livre(s) Emprunté(s)],
Count(Emprunter.Numlivre) AS [Nb de fois]
FROM Inscrit, Livre, Emprunter
WHERE (((Inscrit.NumInscr)=[Emprunter].[NumInscr]) AND
((Livre.NumLivre)=[Emprunter].[Numlivre]))
GROUP BY Inscrit.PrenInscr, Livre.TitreLivre, (Inscrit.NomInscr)
ORDER BY Inscrit.NomInscr, Inscrit.PrenInscr;
=> Affiche dans une table le nom des emprunteurs, les livres qu'ils ont
emprunté et le nombre de fois qu'ils ont emprunté chacun de ces ouvrages.
. Requête4 : Titre(s) non-dispo pour cause de prêt et date de retour
SELECT DISTINCT Inscrit.NomInscr, Inscrit.PrenInscr, Livre.TitreLivre,
Emprunter.DateEmpr+30 AS [Retour Attendu]
FROM Emprunter, Livre, Inscrit
WHERE (((Emprunter.NumInscr)=Inscrit.NumInscr) And
((Emprunter.Numlivre)=Livre.NumLivre) And ((Emprunter.DateRetEff) Is Null))
ORDER BY Emprunter.DateEmpr+30;
(Les doublons existent toujours, pour connaître le premier exemplaire
disponible, il faut choisir la première des lignes qui concernent un
ouvrage en particulier)
=> Affiche dans une table, les emprunteurs, les livres qu'ils ont empruntés
et la date de retour attendue pour chacun des ouvrages. Pour connaître la
date de retour du premier exemplaire en bibliothèque, il suffit de retenir
la première date dans la liste qui apparaît.
. Requête5 : Etat utilisateur-Emprunt en cours-Pénalités
SELECT DISTINCT Emprunter.NumInscr, Inscrit.NomInscr, Inscrit.PrenInscr,
Livre.TitreLivre, Emprunter.DateEmpr+30 AS [Retour Attendu], (Date()-
[Retour Attendu])*0.15 AS Pénalité
FROM Emprunter, Livre, Inscrit
WHERE (((Emprunter.NumInscr)=Inscrit.NumInscr) And
((Emprunter.Numlivre)=Livre.NumLivre) And ((Emprunter.DateRetEff) Is
Null));
=> Affiche dans une table, la liste des utilisateurs actuels, donc des
emprunts en cours et les pénalités encourues aujourd'hui.
. Requête6 : Formulaire Titre donnée info si dispo
SELECT Livre.TitreLivre, Livre.Auteurs, Livre.Editeur, Livre.Nbpage,
Livre.Prix, Livre.Nomfour, Livre.NumLivre
FROM Livre
WHERE (((Livre.NumLivre) Not In (SELECT Numlivre FROM Emprunter)));
SELECT DISTINCT Livre.TitreLivre, Livre.Auteurs, Livre.Editeur,
Livre.Nbpage, Livre.Prix, Livre.Nomfour, Emprunter.Numlivre
FROM Livre, Emprunter
WHERE Livre.NumLivre=Emprunter.Numlivre And
((Emprunter.Numlivre) Not In (SELECT Numlivre FROM Emprunter WHERE
DateRetEff Is NULL)) AND ((Emprunter.DateRetEff) Is Not Null));
SELECT *
FROM [R61 livre jamais empruntés]
Where livre.titrelivre LIKE "*"+ [saisir Titre du livre] + "*"
UNION SELECT *
FROM [R62 Livre déjà sorti mais dispo]
Where livre.titrelivre LIKE "*" + [saisir Titre du livre] + "*";
=> Affiche dans une table la liste des ouvrages qui n'ont jamais été
emprunté ou qui ont déjà été emprunté mais qui ont été restitué à la
bibliothèque.
Modèle Conceptuel de Données (MCD) Gestion d'une Médiathèque
(Modifications apportées au MCD gestion d'une bibliothèque)
[pic]
La cardinalité Inscrit - Emprunter dépend du type d'ouvrage. En effet,
dans le cas où il s'agirait d'un DVD ou d'un CD, un inscrit peut emprunté
de zéro à trois ?uvres, s'il s'agit d'un livre il peut en emprunter jusqu'à
cinq à la fois.
Impact de ces modifications sur les Requêtes :
. Requête1 : Indiquer tous les ouvrages qui n'ont pas été achetés
directement à leur éditeur/producteur
La requête sera la même, mais on y ajoutera une jointure avec la table
« Type Ouvrage » de sorte à faire apparaître le « libellé type » (c'est-à-
dire CD, DVD, Livre) et savoir face à quelle type d'?uvre on se trouve.
Elle se présentera sous la forme d'une table à deux colonnes « Titre et
Type ».
. Requête2 : Afficher tous les couples (emprunteurs, ouvrages empruntés)
En reprenant la requête de base, on ajoutera là aussi une jointure avec
la table « Type Ouvrage » de sorte à faire apparaître le libellé type
(c'est-à-dire CD, DVD, Livre) et savoir face à quelle type d'?uvre on se
trouve. La table présentera alors les colonnes « Emprunteurs, Ouvrages
empruntés et Type ».
. Requête3 : Afficher tous les couples (emprunteurs, ouvrages empruntés)
et en indiquant le nombre d'emprunts par un même utilisateur d'un même
titre
En reprenant la requête de base, on ajoutera là aussi une jointure avec
la table « Type Ouvrage » de sorte à faire apparaître le libellé type
(c'est-à-dire CD, DVD, Livre) et savoir face à quelle type d'?uvre on se
trouve. La table présentera alors les colonnes « Emprunteurs, Ouvrages
empruntés, Type et nombre de fois ».
. Requête4 : Afficher pour chaque titre non-dispo, le nom de
l'emprunteur et la date de retour au plus tôt
En reprenant la requête de base, on ajoutera là aussi une jointure avec
la table « Type Ouvrage » de sorte à faire apparaître le libellé type
(c'est-à-dire CD, DVD, Livre) et savoir face à quelle type d'?uvre on se
trouve. La table présentera alors les colonnes « Emprunteurs, Ouvrages
empruntés, Type et la date de retour attendu ».
Même problème que celui rencontré précédemment « deux dates »
. Requête5 : Afficher la liste des emprunts en cours, les emprunteurs,
les dates de retour attendu et les pénalités éventuelles
En reprenant la requête de base, on ajoutera là aussi une jointure avec
la table « Type Ouvrage » de sorte à faire apparaître le libellé type
(c'est-à-dire CD, DVD, Livre) et savoir face à quelle type d'?uvre on se
trouve. La table présentera alors les colonnes « Emprunteurs, Ouvrages
empruntés, Type,la date de retour attendu et les Pénalités ».
. Requête6 : Afficher les oeuvres non empruntés correspondant à la
demande
En reprenant la requête de base, on ajoutera là aussi une jointure avec
la table « Type Ouvrage » de sorte à faire apparaître le libellé type
(c'est-à-dire CD, DVD, Livre) et savoir face à quelle type d'?uvre on se
trouve. La table présentera alors les colonnes « Titre,
Auteurs/interprètes/réalisateur, Editeur/producteur, Nombre de pages/durée,
Prix, Nom du fournisseur, Numéro de l'?uvre »
Avec cet aménagément de la bibliothèque en médiathèque, les différents
outils de gestion ne sont pas modifiés en profondeur. Il s'agit en effet le
plus souvent de reprendre les anciennes requêtes et de les modifier grâce à
une jointure avec la table « Type ouvrage » pour voir dans la table-
résultat de la requête s'il s'agit bien d'un livre ou d'un DVD ou d'un CD.
Dans le cas où, on avait voulu gérer indifférement les DVD, des CD,
des livres, on aurait pu créer deux autres bases de données sur le modèle
de la première (Gestion d'une Bibliothèque), en remplaçant simplement livre
par son équivalent (d'où la possibilité de réaliser la gestion de la
nouvelle base de données comme nous l'avons présenté).
On pourrait également ajouter une entité DVD et une entité CD avec
tous les attributs qu'elles pourraient avoir. Mais dans ce cas, la
réécriture des requête serait toute autre, nécessitant trois requêtes,
suivant qu'il puisse s'agir d'un DVD, d'un Cd ou d'un livre.
-----------------------
0,n
0,5
0,n
1,1
0,n
FOURNISSEUR
NomFour
AdrFour
VilleFour
CPFour
LIVRE
NumLivre
TitreLivre
Auteur(s)
Editeur
NbPag