Td corrigé Modèle Conceptuel de Données (MCD) Gestion d'une Bibliothèque pdf

Modèle Conceptuel de Données (MCD) Gestion d'une Bibliothèque

B.1 Nouveautés dans l'environnement liées à Windev 16 ..... paye standard) devraient être supprimés, après avoir corrigé les situations de tous les salariés concernés, de telle sorte qu'elles ...... <td style="font-family: arial;">Mois de paye : </td>.




part of the document



Modèle Conceptuel de Données (MCD) Gestion d’une Bibliothèque





 SHAPE \* MERGEFORMAT 




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 ¬ 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)





 SHAPE \* MERGEFORMAT 




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

NbPage

Prix

INSCRIT

NumInscr

NomInscr

PrenomInscr

AdrInscr

VillInscr

CP

Date

DateEmpr

CIF

Emprunter

DateRetEff

PARAMETRE

DuréeEmprunt

Pénalité

Pénalité

DuréeEmprunt

LibelTyp

CodeTyp

TYPE OUVRAGE

DateRetEff


Emprunter Livre DVD CD

CIF

DateEmpr

Date

CP

VillInscr

AdrInscr

PrenomInscr

NomInscr

NumInscr

INSCRIT

Prix

NbPag Durée(min)

NomActeur

Editeur ou producteur

Auteur Inter ou Réal

TitreOuv

NumOuv

OUVRAGE

CPFour

VilleFour

AdrFour

NomFour

"#=>?@ABCD[\]_`abpqr” ø ý 6
7
8
9
:
Y
[
\
c
d
›
œ
óèÚèÖÏÖËÏÿñꦢ˚¢Ë‘‹…‹‘¢Ëó|sibË[ hØO‚hà hØO‚6]h»eDh»eD6]hà>*CJ aJ h3.b>*CJ aJ
h@ˆúÿ
hØO‚@ˆúÿhØO‚hØO‚@ˆúÿhØO‚h3.b>*hàh4{ h»eDh3.bjha'æUmHnHuha'æjha'æUhØO‚ h3.bh3.bh3.bh3.bh3.b6CJ ]aJ h3.bh3.bCJ aJ h3.bh3.b>*CJ aJ #>?@ABC`abcdqrsä  > ” ù 7
8
9
:
Z
[
÷õõõõõõõõõõ÷õõõõõõõõðððõõèõ$a$gdÄ0–gdØO‚$a$gdØO‚™-F\ýý[
\
œ
Ô
 a b Ë   R š œ ž ° ² ´ 2
4
_~ðñòýýôôôïïôïïôôôôêêêâêÝÝÝÕê$a$gdÄ0–gd{c­
& FgdÄ0–gd8Ïgd»eD„Ä`„Ägd»eDœ
§
©
°
Û
ã
 % - V ` b m n Ê Ë Õ Ö Þ à è ê ò ÿ   ˜ š œ ž ´ È Ì 0
2
ïðñòùõíõíõùíùõéâÞÕÎÇÀ¸À¸À¸Àéâ®é¦ž“Š‚{ws{lhshÄ0– h{c­h8Ïh8Ïh{c­ h{c­h{c­h8Ïh8Ï>*h8Ï>*CJ aJ h19h19CJ aJ h19CJ aJ h»eDCJ aJ h»eDh»eD6]h»eDh»eD>* h»eDh»eD h3.bh»eD hØO‚h»eDhØO‚hØO‚@ˆôÿhØO‚ h»eD6]h»eDh3.bh3.b>*h3.b h3.bh3.b'òúý./0©ª)*,4def¦FGHôõ‡ˆ‰‘ËÌûüŸ ­°¸æçè79¼¿ÇÉÊïð`®¯°oúóïëãëÜØÑëÉóëóëØëÅÉóëóÜëØëØúó¾ïë´ëØëÉóúãïëØ¯ÉóªóÉ럗Ÿ hhh8ÏmH sH h8Ïh8ÏmH sH  h{c­>* hÄ0–>*h{c­h{c­6] h{c­h8Ïh19h8Ïh8Ï>* h{c­hÄ0–hÄ0– h8Ïh8Ïh8Ïh{c­>*h8Ïh{c­ h{c­h{c­ h8Ï>*6ò/0ozª«*+,ef÷x¦GH#…Æôõ‡÷òòòòêêòò÷òòòòòêòò÷òòòòòòòê$a$gdÄ0–gd8Ï
& FgdÄ0–‡ˆ‰ÌÍ>]ÜüŸ ®¯°ç虸89º»¼½¾¿úúòúííííåúÝúúòúíííúÝúúúúú$a$gdÄ0–$a$gd{c­gd{c­
& FgdÄ0–gd8Ï¿ðñ`k¯°,Boòóôý^n•Ö×opqrs÷îéééäääääîîßßßßßßß×îîîî$a$gdÄ0–gd{c­gdgd8Ï„Ä`„Ägd»eD
& FgdÄ0–opñòóôÕÖnost–—¥°±Ñëìíîïðñòó
 øíâÚÏËÇüµ±¥šŒµ}s}µÇohÇaYUYhjhU hh hh…]h…]hÕ›hÕ›6]hÕ›h196CJ ]aJ h3.bh196CJ ]aJ h3.bh19CJ aJ h3.bh19>*CJ aJ h19 hh8Ï hhÄ0–hÄ0–h8Ïh{c­h8Ïh19mH sH h8ÏmH sH hh8ÏmH sH hhmH sH hmH sH s±íîïðñò12345›úîååàååÞÞÞÞÞÒÞÊÅÅÅŽ
& Fgd/Ëgdÿt$a$gdÿt $„Ä`„Äa$gd˜6 gd…]„Ä`„Ägd»eD $„Ä`„Äa$gdÕ›gd19  
„‰ÿ15=š›Ç Ï
!!!`!b!n!£"×"Ø"*#,#8#$&$†$ˆ$Ù$Û$ç$Ö%×%&&&òêâÛÔÐÌÈÄȽ̹°Ä¨Ä Ä¨Ä¨›”ĔĐĉ‰‰‰Ìwp h/Ë6]h/Ëh/Ë6]h/Ëh/Ë>* hÿth/Ëh/Ë hÿthÿt hÿt>*h/Ëhÿt>*hÿthÿt>*hÿt>*CJ aJ hÕ› hXAJhXAJhÿthhXAJh8Ï hXAJh8Ï hh8ÏjhUjhUjhUmHnHu,›œÅ Æ Ç !!B"C"D"Ø"Ù"$$$‡$ˆ$Ö%×%&&&öêââ×âêââ×ÏêÏÏÄÏê¿·¿¿$a$gd/Ëgd/Ë $
& Fa$gd/Ë$a$gd/Ë $
& Fa$gdÿt$a$gdÿt $„h`„ha$gd˜6 „h^„hgd˜6 &&–&ç&é&õ&ó'û';(=(>((‘(())Ä)Æ)Ç)8+×+ñ+˜-™-œ-ž-¡-£-¦-¨-«-­-°-²-½-¿-Æ-È-Ï-Ñ-Ú-Ü-â-ä-é-ë-ó-õ-ÿ-.
. .....!.#.*.,.4.÷óìóìó÷åóåìóìóåóáóáÝÓÝ̶²¶²¶²¶²¶²¶²š²¶²¶²¶²¶²š²¶²¶²¶²¶²¶²¶²š.ha'æ>*B*CJOJQJ^JaJmH phsH ha'æ+ha'æB*CJOJQJ^JaJmH phsH  h/Ëh™5ãh™5ãh™5ã6]h™5ãh˜6 h/Ëh/Ë hÿth/Ëh/Ëh/Ëh/Ë>**B*CJOJQJ^JaJmH phsH +ha'æB*CJOJQJ^JaJmH phsH ha'æ