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

Schéma Discussion :

attribut multivalué [MCD]


Sujet :

Schéma

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 73
    Points : 53
    Points
    53
    Par défaut attribut multivalué
    Bonjour,
    Apres quelques recherches j'ai tj du mal avec les attributs multivalués.
    Voila un cas simple : le Loto
    J'ai une table TIRAGE et BALLE
    Tirage : PK numero_tirage,balle(multivalué (1-9)), date_inscription
    Balle : PK numero_balle,couleur

    En gros chaque balle dans tirage est une clef étrangère de Balle, car chaque balle sorti possede un numero et une couleur

    Pour le MCD je ne vois pas du tout comment faire, je pensais faire une relation pour chaque balle, donc de 1 a 9, vers Balle

    Pourriez vous m'aider a représenter cela en MCD ? et si quelqu'un connais PowerAmc comment on le représente dessu ?

    Merci d'avance

  2. #2
    Membre éprouvé Avatar de Oishiiii
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2009
    Messages
    508
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Août 2009
    Messages : 508
    Points : 1 104
    Points
    1 104
    Par défaut
    Bonjour,

    Un tirage comporte plusieurs balles.
    Une même balle peut sortir pour plusieurs tirages.

    Cela se traduit au niveau du MCD par deux entités; TIRAGE et BALLE, ainsi qu'une association qui les relient avec des cardinalité 0,N sur chaque patte.
    Comme ceci:

    TIRAGE -0,N-------(SORT)-------0,N- BALLE

    Une fois au niveau du MLD, l'association SORT deviendra une table dont la clé primaire est composée de deux clé étrangères faisant références aux tables Tirage et Balle.

  3. #3
    Expert éminent sénior
    Avatar de fsmrel
    Homme Profil pro
    Spécialiste en bases de données
    Inscrit en
    Septembre 2006
    Messages
    8 001
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Spécialiste en bases de données
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2006
    Messages : 8 001
    Points : 30 905
    Points
    30 905
    Billets dans le blog
    16
    Par défaut
    Grâce à Oishiiii, vous avez sorti les bons numéros, ce qui fait qu’avec Power AMC, votre MCD ressemble à ceci :



    Et votre MLD :



    Et l’outil vous génère le code SQL de création des tables :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
     
    Create Table TIRAGE
     (
       TirageNo             Int                  Not null,
       TirageDate           Datetime             Not null,
       Constraint TIRAGE_PK Primary Key  (TirageNo),
       Constraint TIRAGE_AK Unique (TirageDate)
     ) ;
    Create Table Balle
     (
       BalleNo              Int                  Not null,
       Couleur              Varchar(16)          Not null,
       Constraint Balle_PK Primary Key  (BalleNo)
     ) ;
    Create Table SORTIR
     (
       TirageNo             Int                  Not null,
       BalleNo              Int                  Not null,
       Constraint SORTIR_PK Primary Key  (TirageNo, BalleNo),
       Constraint SORTIR_TIRAGE Foreign Key (TirageNo)
          References Tirage (TirageNo) ON DELETE CASCADE,
       Constraint SORTIR_Balle Foreign Key (BalleNo)
          References Balle (BalleNo)
     ) ;

    N.B. L’attribut TirageDate fait l’objet d’une clé alternative pour la table TIRAGE dans la mesure où il n’y a qu’un tirage par jour. Dans le cas contraire, supprimer cette contrainte.
    (a) Faites simple, mais pas plus simple ! (A. Einstein)
    (b) Certes, E=mc², mais si on discute un peu, on peut l’avoir pour beaucoup moins cher... (G. Lacroix, « Les Euphorismes de Grégoire »)
    => La relativité n'existerait donc que relativement aux relativistes (Jean Eisenstaedt, « Einstein et la relativité générale »)

    __________________________________
    Bases de données relationnelles et normalisation : de la première à la sixième forme normale
    Modéliser les données avec MySQL Workbench
    Je ne réponds pas aux questions techniques par MP. Les forums sont là pour ça.

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 73
    Points : 53
    Points
    53
    Par défaut
    euuu ouai alors moi j'ai mis aussi 1,n, cela me paraissait plus logique
    Ensuite retirer balle1* dans Tirage...oui effectivement, je suis bete j'aurais du y penser lol

    Par contre "<ai>" dans Tirage sur TirageDate c'est quoi ??


    merci pour les infos
    Images attachées Images attachées  

  5. #5
    Expert éminent sénior
    Avatar de fsmrel
    Homme Profil pro
    Spécialiste en bases de données
    Inscrit en
    Septembre 2006
    Messages
    8 001
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Spécialiste en bases de données
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2006
    Messages : 8 001
    Points : 30 905
    Points
    30 905
    Billets dans le blog
    16
    Par défaut
    Citation Envoyé par Kruggs Voir le message
    "<ai>" dans Tirage sur TirageDate c'est quoi ??
    Dans mon message précédent, j’ai écrit :
    L’attribut TirageDate fait l’objet d’une clé alternative pour la table TIRAGE dans la mesure où il n’y a qu’un tirage par jour. Dans le cas contraire, supprimer cette contrainte.
    Cette clé alternative (alternate key, en abrégé « ak ») permet de garantir, si tel est le cas, qu’à une date donnée il n’y a qu’un seul tirage.
    Si l’on remonte au niveau conceptuel, on parle alors d’identifiant alternatif (alternate identifier, en abrégé « ai »).
    (a) Faites simple, mais pas plus simple ! (A. Einstein)
    (b) Certes, E=mc², mais si on discute un peu, on peut l’avoir pour beaucoup moins cher... (G. Lacroix, « Les Euphorismes de Grégoire »)
    => La relativité n'existerait donc que relativement aux relativistes (Jean Eisenstaedt, « Einstein et la relativité générale »)

    __________________________________
    Bases de données relationnelles et normalisation : de la première à la sixième forme normale
    Modéliser les données avec MySQL Workbench
    Je ne réponds pas aux questions techniques par MP. Les forums sont là pour ça.

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 73
    Points : 53
    Points
    53
    Par défaut
    j'avais pas fait attention dsl.
    Je ne connaissait pas ce terme, en MCD sur power amc ou sur papier cela se symbolise comment ?
    Et en MLD aussi niveau papier ? on souligne aussi ?

  7. #7
    Expert éminent sénior
    Avatar de fsmrel
    Homme Profil pro
    Spécialiste en bases de données
    Inscrit en
    Septembre 2006
    Messages
    8 001
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Spécialiste en bases de données
    Secteur : Conseil

    Informations forums :
    Inscription : Septembre 2006
    Messages : 8 001
    Points : 30 905
    Points
    30 905
    Billets dans le blog
    16
    Par défaut
    Je décris le processus de création d'identifiant alternatif selon la V11 de Power AMC.

    Il semblerait que ce soit plus simple avec la V15 (que je n'ai pas) :

    Modélisation des données > Construction de diagrammes conceptuels et logiques de données > Identifiants (MCD/MLD) > Création d'un identifiant


    Au niveau MCD (V11)

    Pour signifier que l’attribut TirageDate fait l’objet d'un identifiant alternatif, double-cliquez sur l’entité-type TIRAGE, apparaît la fenêtre "Propriétés de l’entité".

    Cliquez sur l’onglet "Identifiants".

    Cliquez sur la ligne vide sous la ligne qui contient « idntifiant_1 ». l’AGL affiche un nouvel identifiant qu’il nomme Identifiant_2, mais dont il ne sait pas encore quel(s) attribut(s) le composent.

    Cliquez sur le bouton "Appliquer" (en bas de la fenêtre "Propriétés de l’entité").

    Quand le bouton "Appliquer" est en grisé, double-cliquez sur identifiant_2.

    Apparaît une fenêtre : "Propriétés de l’identifiant..."

    Cliquez sur l'onglet "Attributs"

    Vous cliquez ensuite sur l’icône "Ajouter des attributs" (l’icône à droite de la main qui tient une feuille).

    Apparaît la liste des attributs de l’entité-type. Vous cochez la case TirageDate puis vous faites "OK" en rafale.

    Dans le MCD graphique, la propriété TirageDate doit maintenant être accompagnée de la mention <ai> (pour "alternate identifier"). Ouf !

    AU niveau MLD

    Vous n'aurez rien à faire, ça sera automatiquement répercuté par l'AGL.
    (a) Faites simple, mais pas plus simple ! (A. Einstein)
    (b) Certes, E=mc², mais si on discute un peu, on peut l’avoir pour beaucoup moins cher... (G. Lacroix, « Les Euphorismes de Grégoire »)
    => La relativité n'existerait donc que relativement aux relativistes (Jean Eisenstaedt, « Einstein et la relativité générale »)

    __________________________________
    Bases de données relationnelles et normalisation : de la première à la sixième forme normale
    Modéliser les données avec MySQL Workbench
    Je ne réponds pas aux questions techniques par MP. Les forums sont là pour ça.

  8. #8
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    73
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Juillet 2007
    Messages : 73
    Points : 53
    Points
    53
    Par défaut
    oki, merci bien pour toutes ces informations

    Bonne journée

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. LDAP: recherche sur un attribut multivalué
    Par yjuliet dans le forum Sécurité
    Réponses: 1
    Dernier message: 13/10/2008, 17h59
  2. Filtre d'affichage de balise selon leur attributs
    Par Norely dans le forum XML/XSL et SOAP
    Réponses: 10
    Dernier message: 03/04/2003, 14h33
  3. Une fonction avec des attributs non obligatoires
    Par YanK dans le forum Langage
    Réponses: 5
    Dernier message: 15/11/2002, 13h39
  4. Lire un attribut dans un fichier XML en C++
    Par ti.k-nar dans le forum XML
    Réponses: 2
    Dernier message: 14/10/2002, 15h22
  5. comment changer d'attribut de fonte dans un Tlabel?
    Par sb dans le forum Composants VCL
    Réponses: 3
    Dernier message: 21/08/2002, 16h53

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