Précédent   Forum des professionnels en informatique > Bases de données > Décisions SGBD
Décisions SGBD Forum de décisions sur le choix en bases de données. Le Comparatif
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 15/06/2006, 14h41   #1
Membre habitué
 
Inscription : avril 2004
Messages : 646
Détails du profil
Informations forums :
Inscription : avril 2004
Messages : 646
Points : 106
Points : 106
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.
soso78 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2006, 14h45   #2
Inactif
 
Avatar de Médiat
 
Inscription : décembre 2003
Messages : 1 946
Détails du profil
Informations forums :
Inscription : décembre 2003
Messages : 1 946
Points : 1 932
Points : 1 932
Non, car cela ne ressemble pas une relation en première forme normale...
Médiat est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2006, 15h07   #3
Modérateur
 
Avatar de al1_24
 
Homme Alain
Ingénieur d'études décisionnel
Inscription : mai 2002
Messages : 4 446
Détails du profil
Informations personnelles :
Nom : Homme Alain
Âge : 51
Localisation : France, Val de Marne (Île de France)

Informations professionnelles :
Activité : Ingénieur d'études décisionnel
Secteur : Conseil

Informations forums :
Inscription : mai 2002
Messages : 4 446
Points : 7 546
Points : 7 546
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
al1_24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2006, 15h11   #4
Membre habitué
 
Inscription : avril 2004
Messages : 646
Détails du profil
Informations forums :
Inscription : avril 2004
Messages : 646
Points : 106
Points : 106
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" ?
soso78 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2006, 15h17   #5
Modérateur
 
Avatar de al1_24
 
Homme Alain
Ingénieur d'études décisionnel
Inscription : mai 2002
Messages : 4 446
Détails du profil
Informations personnelles :
Nom : Homme Alain
Âge : 51
Localisation : France, Val de Marne (Île de France)

Informations professionnelles :
Activité : Ingénieur d'études décisionnel
Secteur : Conseil

Informations forums :
Inscription : mai 2002
Messages : 4 446
Points : 7 546
Points : 7 546
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 !
al1_24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2006, 15h21   #6
Membre habitué
 
Inscription : avril 2004
Messages : 646
Détails du profil
Informations forums :
Inscription : avril 2004
Messages : 646
Points : 106
Points : 106
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.
soso78 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2006, 18h13   #7
Expert Confirmé Sénior
 
Avatar de qi130
 
Homme Pierre
Ingénieur qualité méthodes
Inscription : mars 2003
Messages : 3 726
Détails du profil
Informations personnelles :
Nom : Homme Pierre
Âge : 51
Localisation : France

Informations professionnelles :
Activité : Ingénieur qualité méthodes
Secteur : Finance

Informations forums :
Inscription : mars 2003
Messages : 3 726
Points : 4 739
Points : 4 739
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
qi130 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 13h08.


 
 
 
 
Partenaires

Hébergement Web