Travaux dirigés 5

Transcription

Travaux dirigés 5
Travaux dirigés 5
Bases deèredonnées
IMAC 1 année
Modélisation conceptuelle
x Exercice
1. Schéma relationnel 1
Lors d'une élection communale, faisant de tout secret électoral, un informaticien malfaisant réussit à se procurer et à stocker dans une base de données relationnelle les informations
suivantes : pour chaque commune (avec son nom et son nombre d'électeurs potentiels) les
électeurs ayant voté (nom, prénom, adresse et heure du vote), les candidats (nom, prénom,
position sur la liste du parti) pour lesquels ils ont voté (un électeur pouvant en eet voter pour
plusieurs candidats) ainsi que le parti pour lequel ils ont voté (les candidats pour lesquels ils
votent doivent être du même parti).
Notre informaticien veut aisément pouvoir comptabiliser le nombre de voix attribuées à
chaque parti et à chaque candidat pour chaque commune et aisément retrouver les électeurs
ayant voté dans chaque commune pour chaque candidat et chaque parti.
Réalisez les tables (avec leurs attributs) et le schéma relationnel décrivant la base de
données en question et permettant à notre informaticien d'acquérir cette connaissance.
x Exercice
2. Schéma relationnel 2
Une agence immobilière gère la location d'appartements et de maisons pour le compte de
propriétaires. Cette agence maintient une base de données relationnelles dans laquelle chaque
propriétaire (nom, prénom,adresse,tel.) remet en gestion à l'agence plusieurs appartements
ou maisons (taille, adresse, prix de location) selon un contrat (durée, pourcentage) propre à
chaque bien.
Chaque appartement ou maison est donnée en location par un bail identié par un numéro
et pour une période déterminée, à un locataire dont on enregistre le nom, prénom, adresse,
tél.
Réalisez le schéma relationnel d'une telle base de données.
1
x Exercice
3. Schéma relationnel 3
Un fanatique de cinéma et de festivals de lms décide de réaliser sa base de données personnelle en y stockant les diérents festivals de cinéma (Venise, Canne, Bruxelles,. . .avec pour
chacun le lieu et le directeur) et ce pour chaque année où ils se déroulent. Pour chaque festival,
il désire également enregistrer les lms qui y furent en compétition (titre, réalisateur,. . .), les
acteurs (nom, nationalité, lms en compétition dans lesquels ils ont tourné) et les réalisateurs
(nom, lm en compétition qu'ils ont réalisé) présents durant le festival.
Finalement, il veut, et ce pour chaque festival encore, encoder à part le lm qui a remporté
le grand prix et l'acteur ayant remporté le prix du meilleur rôle.
Réalisez le schéma relationnel d'une telle base de données.
x Exercice
4. Le même mais en plus complexe cette fois
1. Introduction
Une société de transport aérien décide de repenser l'implantation de son système d'information en évoluant d'une approche chiers vers une approche BD relationnelle. Pour mener
à bien cette opération, la direction informatique de l'entreprise adopte une démarche en deux
phases : une première phase dédiée à la conception des données et des traitements, et une
seconde phase consacrée à l'implantation des données et des traitements à l'aide du SGBD
relationnel retenu.
Le but de l'étude de cas proposée est de réaliser la phase de conception des données
uniquement. La démarche préconisée est de représenter la réalité de l'entreprise en utilisant
le modèle entité-association, étendu avec le concept de généralisation, avec la prise en compte
des contraintes d'intégrité (en particulier les dépendances fonctionnelles). Le résultat de cette
modélisation est constitué par un schéma conceptuel au format entité/association étendu. Ce
schéma conceptuel doit alors être transformé en un schéma relationnel normalisé équivalent.
2. Description du système d'information
Pour vous permettre de construire le schéma conceptuel de la base, nous donnons maintenant la description des informations à gérer au sein de l'entreprise de transport aérien.
L'objectif est d'assurer la gestion, d'une part des employés, des vols et des appareils,
d'autre part des clients et des billets.
L'ensemble des employés se compose du personnel navigant et du personnel au sol. Parmi
le personnel navigant, on distingue les pilotes et les membres d'équipage (hôtesses, stewart,
...).
Un employé est caractérisé par un numéro de sécurité sociale, un nom, un prénom, une
adresse et un salaire. Un personnel navigant comptabilise un certain nombre d'heures de
vol. Un pilote possède une licence dénie par un numéro. Un membre d'équipage assure une
certaine fonction (hôtesse, stewart, ...).
Un appareil est identié de manière unique par un numéro d'immatriculation. Il possède
un type (A320, B747, ...) et il ore une certaine capacité en nombre de passagers.
Chaque liaison desservie par au moins un vol de la compagnie est dénie par une ville
d'origine et une ville de destination ; de plus, elle est identiée par un numéro.
2
Un vol est identié par un numéro de vol. Il est caractérisé par une période de validité
dénie par deux dates. Durant cette période, ce vol a des horaires xes (heure départ et heure
arrivée). Un vol dessert une liaison et une seule. Qui plus est, un appareil et un seul est associé
à un vol donné.
Pour chaque vol enregistré, on suppose qu'il existe un départ tous les jours pendant la
période de validité de ce vol. Un départ est déni par un numéro de vol et une date de départ.
A un départ sont associés un ou deux pilotes et deux à quatre membres d'équipage. Un départ
est également caractérisé par un nombre de places libres et un nombre de places occupées.
Une place occupée est une place ayant donnée lieu à une réservation avec émission d'un billet.
Un passager est identié par un numéro. Il possède un nom, un prénom, une adresse, une
profession et une banque. Il eectue des réservations qui donnent lieu à l'émission de billets.
Un billet est repéré par un numéro. Il comporte une date d'émission et un prix. Un billet
référence un départ et un seul. Pour simplier, on suppose qu'un billet concerne un client et
un seul.
3 Questions
Comme pour les autres exercices, modèle entité-association, schéma relationnel.
3