Super-héros relationnels I
[20 min]
La gamme de super-héros GARVEL veut réaliser la base de données de leurs figurines articulées. La société a fait réaliser un modèle UML qui doit servir de point de départ à la mise en œuvre.
Question
Transformer le modèle UML en modèle relationnel (justifier les passages non triviaux, en particulier la relation d'héritage).
Solution
Personnage (#designation:string, prix:float, identiteSecrete:string, genre:{superhéro, supervilain}, mentor=>Personnage(designation))
Vehicule (#designation:string, prix:float, nbPlaces:integer, type:{terrestre, volant, aquatique}, conducteur=>Personnage(designation)) WITH conducteur NOT NULL
Repaire (#designation:string, prix:float, emplacementGeographique:string, capacite:integer)
Membre (#proprietaire=>Personnage(designation), #nom:{tête, bras gauche, bras droit, torse, jambe gauche, jambe droite}, couleur:string)
Abrite (#repaire=>Repaire(designation), #personnage=>Personnage(designation))
Contrainte : Projection(Personnage.designation) = Projection(Membre.proprietaire)
Remarque : Héritage
On choisit l'héritage par les classes filles (on est dans un des cas simples).
L'héritage est non complet, un héritage par la classe mère serait une erreur.
L'héritage par référence est une mauvaise solution qui complexifie pour rien le modèle.
Remarque : Clé candidate "identiteSecrete"
Nous pourrions décider que identiteSecrete est une clé candidate, bien que la diagramme UML ne le précise pas.
Remarque : Vue vFigurine
La vue vFigurine
est optionnelle, la classe mère étant abstraite.
vFigurine = Union ( Union (Projection(Personnage,designation,prix), (Projection(Vehicule,designation,prix)), Projection(Repaire,designation,prix))