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

Décisions SGBD Discussion :

Problème de modélisation avec Case Studio


Sujet :

Décisions SGBD

  1. #1
    Membre habitué

    Inscrit en
    Avril 2004
    Messages
    646
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 646
    Points : 145
    Points
    145
    Par défaut Problème de modélisation avec Case Studio
    Salut,

    Dans le cadre de la modélisation de ma base de données, j'utilise Case Studio.

    Or, j'ai un problème pour modéliser le schéma suivant :

    - j'ai une entité nommé "RUBRIQUE",
    - une autre nommé "FOURNISSEUR"

    Je souhaite créer une relation entre l'entité RUBRIQUE et FOURNISSEUR. Jusque là, tout va bien. Le hic, c'est que l'on peut choisir jusqu'à 4 rubriques par fournisseurs.

    Comment faire ?

    J'ai essayé de créer plusieurs relations entre RUBRIQUE et FOURNISSEUR mais Case Studio m'affiche une erreur signalant que l'attribut est identique "CODE_RUBRIQUE".

    Idéalement, je souhaiterais que la table "FOURNISSEURS" corresponde à ceci :

    - IDFRS (clé primaire),
    - FOURNISSEUR (nom),
    - CODE_RUBRIQUE1 (1ère rubrique pointant sur l'entité "RUBRIQUE"),
    - CODE_RUBRIQUE2 (2ème rubrique pointant sur l'entité "RUBRIQUE"),
    - CODE_RUBRIQUE3 (rubrique pointant sur l'entité "RUBRIQUE"),
    - CODE_RUBRIQUE4 (4ème rubrique pointant sur l'entité "RUBRIQUE");

    Pouvez-vous m'aider à modéliser ce schéma ?

    Merci par avance.

  2. #2
    Inactif   Avatar de Médiat
    Inscrit en
    Décembre 2003
    Messages
    1 946
    Détails du profil
    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 946
    Points : 2 227
    Points
    2 227
    Par défaut
    Non, car cela ne ressemble pas une relation en première forme normale...
    J'affirme péremptoirement que toute affirmation péremptoire est fausse
    5ième élément : barde-prince des figures de style, duc de la synecdoque
    Je ne réponds jamais aux questions techniques par MP

  3. #3
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 803
    Points
    30 803
    Par défaut
    Tu pourras éventuellement faire ça au niveau de la modélisation physique de ta base, mais au niveau logique tu auras :
    une entité Fournisseur
    une entité Rubrique
    une relation entre les deux avec les cardinalités qui vont :
    Rubrique -> Fournisseur : 0,n
    Fournisseur -> Rubrique : 0,4
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  4. #4
    Membre habitué

    Inscrit en
    Avril 2004
    Messages
    646
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 646
    Points : 145
    Points
    145
    Par défaut
    Salut,

    Si je comprends bien, au niveau logique, on n'aura qu'une relation "RUBRIQUE" <--> "FOURNISSEUR".

    Comment gérer ce modèle pour la modélisation "physique" ?

  5. #5
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Retraité
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 803
    Points
    30 803
    Par défaut
    Citation Envoyé par esoso
    Comment gérer ce modèle pour la modélisation "physique" ?
    Soit la structure que tu proposais (pabo )
    Soit une table de relation (ID_FRNSR, CODE_RUBRIQUE) beaucoup plus propre au niveau de la normalisation !
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  6. #6
    Membre habitué

    Inscrit en
    Avril 2004
    Messages
    646
    Détails du profil
    Informations forums :
    Inscription : Avril 2004
    Messages : 646
    Points : 145
    Points
    145
    Par défaut
    Salut,

    Effectivement ta solution me semble meilleure. Cependant, j'avais appris, il y a déjà quelques temps qu'on pouvait réaliser un CIF (Contrainte d'Intégrité Fonctionnelle). Et que c'était là l'exemple adéquat.

    Dans quelle cas doit-on utiliser un CIF plutôt qu'une entité / relation ?

    Merci.

  7. #7
    Expert éminent
    Avatar de qi130
    Homme Profil pro
    Expert Processus IT
    Inscrit en
    Mars 2003
    Messages
    3 902
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France

    Informations professionnelles :
    Activité : Expert Processus IT
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2003
    Messages : 3 902
    Points : 6 026
    Points
    6 026
    Par défaut
    Concernant ton problème initial d'attributs de même nom, ce n'est pas bloquant.

    J'ai aussi fait quelques modèles ayant ce cas de figure, et rien n'empêche CaseStudio de générer le SQL de création.

    2 manières de faire:
    1/ tu crées normalement tes 4 "relations", puis tu reviens en edit sur la table ayant les FK, tu édites ces FK pour en changer le nom physique (on ne peut pas changer le nom logique)
    A la sauvegarde de la table par [Ok] tu auras le msg, tu fais Yes. Tu auras aussi ce warning lors de la vérification du modèle...

    Mais comme la génération utilise le nom physique, tout va bien.

    2/ au lieu de créer directement une relation donnant une FK, tu commences par ajouter dans ta table un attribut qui servira de cible à ta FK. Puis tu crées une relation "informative" en partant de la table foreign. Puis, edit de la relation pour positionner son type à Non identifying, puis [Ok]. la FK "classique" apparait, en plus de l'attribut que tu viens d'ajouter.
    Puis, clic-droit sur la relation, choisir Foreign Keys. Dans la fenêtre, clic sur la cellule de la colonne New FK, 1 combobox se dessine, tu n'as plus qu'à choisir ton attribut, puis [Ok].
    Alors, dans ta table, ton attribut est marqué FK, et l'attribut hérité de la modification de la relation a disparu.

    C'est la méthode académique , mais perso, j'utilise plus souvent la première...
    "Il n'y a pas de bonnes réponses à une mauvaise question." (M. Godet)
    -----------------------
    Pensez à cloturer votre sujet - Aucune réponse aux sollicitations techniques par MP
    Usus magister est optimus

Discussions similaires

  1. problème de compilation avec Visual Studio 6.0 (Win.XP)
    Par KINGINFO dans le forum SL & STL
    Réponses: 1
    Dernier message: 29/11/2008, 01h01
  2. Problème de conception avec cases à cocher
    Par jbx50 dans le forum Modélisation
    Réponses: 4
    Dernier message: 27/03/2008, 11h28
  3. Problème slider MFC avec visual studio
    Par superjoe dans le forum MFC
    Réponses: 4
    Dernier message: 03/05/2007, 09h53
  4. Réponses: 2
    Dernier message: 15/03/2007, 12h10
  5. [SQL server 2000] Problème de jointure avec 'Case'
    Par Tankian dans le forum Langage SQL
    Réponses: 2
    Dernier message: 28/06/2006, 17h42

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