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 :

Problème modélisation et passage MCD -> MLD


Sujet :

Schéma

  1. #1
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 5
    Points : 4
    Points
    4
    Par défaut Problème modélisation et passage MCD -> MLD
    Bonjour,
    je suis en train de modéliser une système dont je vous donne un extrait dans l'image ci joint.Nom : MCD.png
Affichages : 417
Taille : 2,8 Ko
    Dans cet extrait de MCD, 3 entités et 2 associations. J'essaie d'y stocker des informations sur des clients et des agences. L'extrait montre plus particulièrement la façon de stocker l'information d'adresse pour les clients et les agences. Je souhaite stocker toutes les adresses dans la même table (que ce soit des adresses client ou des adresses d'agence)

    Les entités ne m'intéresse pas particulièrement toutefois :
    - L'entité Adresse permet de stocker des adresses.
    - L'entité Client permet de stocker les informations des clients.
    - L'entité Agence permet de stocker des renseignements sur des agences ou commerces

    Ce qui m'interesse beaucoup plus, ce sont les deux associations.
    L'association Habiter (entre Adresse et Client) est classique : un client habite à une et une seule adresse mais à une adresse peux correspondre plusieurs clients (le mari, la femme et pourquoi pas les enfants et les poissons rouges ^^.
    C'est la seconde qui me pose problème. L'association Situer entre Agence et Adresse. Une agence est située à une et une seule adresse d'où ma cardinalité 1,1 du côté Agence. Par contre, à une adresse peut correspondre une agence mais bien souvent aucune agence d'où ma cardinalité 0,1.

    Jusque là, tout peut paraitre normal. Lorsqu'on passe du MCD au MLD, on obtient ceci pour les tables Agence et Adresse :
    Agence (AGE_id, AGE_nom, #ADR_id)
    Adresse (ADR_id, ADR_num, ADR_rue, ADR_cp, ADR_ville, #AGE_id)
    (le # signifie une clé étrangère)

    Mon problème se pose à ce niveau. En effet, la clé étrangère #ADR_id dans la table Agence me semble tout à fait correct. On fait bien référence à une adresse dans la table Agence pour pouvoir la situer. Par contre, la clé étrangère #AGE_id (possiblement NULL) dans la table Adresse me semble inutile voire même dangereuse dans le sens où si elle est renseignée, il faut être bien sûr que l'agence correspondant soit bien située à la bonne adresse.

    Bref, ce que j'aurais souhaité :
    Agence (AGE_id, AGE_nom, #ADR_id)
    Adresse (ADR_id, ADR_num, ADR_rue, ADR_cp, ADR_ville)
    (le # signifie une clé étrangère)

    Le plus simple pour obtenir ceci est de mettre une cardinalité 1,N à place du 0,1. Dans ce cas, j'obtiens le MLD voulu mais cela ne reflète plus la réalité.

    Y-a-t-il une solution à ce problème ?

    Cordialement

  2. #2
    Membre confirmé
    Avatar de tse_jc
    Homme Profil pro
    Data Solutions
    Inscrit en
    Août 2010
    Messages
    287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Data Solutions
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2010
    Messages : 287
    Points : 597
    Points
    597
    Billets dans le blog
    4
    Par défaut
    Bonjour et bonne année

    Votre deuxième proposition de modèle est la bonne dans le contexte ennoncé. Rappel:
    Agence (AGE_id, AGE_nom, #ADR_id)
    Adresse (ADR_id, ADR_num, ADR_rue, ADR_cp, ADR_ville)
    C'est à dire qu'une adresse peut soit correspondre à l'adresse d'une agence soit à celle d'un client, soit être orpheline (cas d'une création d'adresse en vue d'être affecté à une agence ou à un client ou cas d'un changement d'adresse d'un client ou d'une agence dans un contexte où il est conservé un historique des adresses pour chaque entité en relation).

    Le souci est de pouvoir préserver l'intégrité référentielle si votre modèle relationnel est conservé ainsi. En effet cela oblige à définir l'adresse préalablement à la création d'une agence. Or si vous êtes dans un contexte de production où l'adresse d'une agence peut ne pas être connu, cela vous oblige à passer par une table de jonction modélisant cette relation : agenc_addr(AGEN_id,ADR_id) où AGEN_id et ADR_id composent alors la clé primaire de cette entité.

  3. #3
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 5
    Points : 4
    Points
    4
    Par défaut
    Merci pour la réponse et bonne année effectivement

    Tout à fait d'accord sur le MLD correspondant à la solution mais comment cela se modélise-t-il sur le MCD et notamment pour les cardinalités de l'association situer entre agence et adresse ?

    Si l'on suit les règles de passage d'un MCD au MLD, il me semble (mais je peux me tromper) que je n'ai pas trop le choix et que je doive mettre du 1,1 - 1,N. Et ceci ne reflète plus la réalité...

    J'ai peut être raté qqchose ??!!

    Sinon, non ce n'est pas dans un contexte de production... Ouf !

  4. #4
    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
    Bonsoir sywave,


    Depuis que Merise existe, la règle en cause pour passer du MCD au MLD est défectueuse...

    Par contre, en utilisant par exemple la notation Entité/Association de l’AGL PowerAMC, à partir du MCD :



    Par dérivation, on obtient le MLD (correct) :





    Autrement dit, si votre AGL de modélisation ne sait pas faire, alors vous supprimerez manuellement la colonne parasite dans la table ADRESSE, cause d’un cycle qui n’a rien à faire ici. Vous n’allez quand même pas modifier une règle de gestion de données à cause de la carence d’un outil de modélisation ou de la façon parfois fort étrange dont ceux qui ont fait Merise perçoivent la théorie relationnelle...
    (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.

  5. #5
    Candidat au Club
    Homme Profil pro
    Inscrit en
    Juin 2011
    Messages
    5
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Juin 2011
    Messages : 5
    Points : 4
    Points
    4
    Par défaut
    Merci de vos réponses !

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

Discussions similaires

  1. Problème de passage MCD -> MLD avec ModelSphere
    Par cover70 dans le forum Modélisation
    Réponses: 3
    Dernier message: 12/12/2012, 00h49
  2. Passage MCD vers MLD. Créer la table jointure.
    Par Oishiiii dans le forum PowerAMC
    Réponses: 6
    Dernier message: 24/03/2010, 21h49
  3. [MLD] Passage mcd au mld: 2 associations pour 2 entités
    Par kaso54 dans le forum Schéma
    Réponses: 4
    Dernier message: 10/10/2009, 11h59
  4. Passage MCD complexe à MLD, conseil pour le MCD
    Par Kalion dans le forum Schéma
    Réponses: 9
    Dernier message: 22/10/2008, 13h41
  5. Passage du MCD en MLD en MPD
    Par shinshon dans le forum Schéma
    Réponses: 3
    Dernier message: 02/11/2005, 15h42

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