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 :

Comment gérer différents types d'articles dans un stock


Sujet :

Schéma

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Août 2005
    Messages
    48
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 48
    Points : 28
    Points
    28
    Par défaut Comment gérer différents types d'articles dans un stock
    Bonjour,


    Dans mon apprentissage je souhaite realiser une BD "simple" (simplifiée disons) de gestion de stock (genre stock d'un easycash) où on peut y trouver differents types d'articles.
    Donc 1ère étape le MCD.

    Comme entité principale j'ai donc opté pour Article, qui se caracterisera par:
    -id
    -nom
    -categorie
    -....

    Et deja là je commence à avoir des noeuds au cerveau .
    Si j'ai bien capté ce que j'ai lu concernant la methode Merise il faut, si ce n'est imperativement, en tout cas tendre le plus possible vers des entites comportant des données qui n'auront pas un trop grand nombre de possibilités et si possible meme un seul choix (exemple: prénom n'a qu'une seule possibilité, Nom pareil, etc...).

    Or deja là des categories possibles va y en avoir plusieurs forcement (encore que suivant comment on se place...bref).
    Donc je vais créer une table "Categorie" OK .... en plus selon la règle des (X,1)-(X,n) ça semble bien tomber, la clé primaire de la table Categorie
    sera donc la clé étrangère de la table Article (une categorie peut concerner plusieurs articles, alors qu'un article n'est sensé n'appartenir qu'à une seule categorie... encore que là aussi... bref).


    Par contre.. et c'est là que le "noeud" se serre... un article va se caracteriser par d'autres détails, ces details dependants justement des categories concernées.
    Un vetement va necessiter de renseigner les dimensions, la couleur, aura aussi lui-meme ses "categories" d'ailleurs (ville ou sportwear, pantalon ou manteau, jean ou cuir,etc..), tandis que pour un CD on aura d'autres criteres plus adéquates (on s'en fout de sa couleur et ses dimensions...).


    Et là je commence à etre perdu.... faut recréer des des tables "sous-categories" genre Vetement, CD, Livres, etc... tout simplement?
    Et quelle type de realtion les relie? (au debut c'etait simple " Article --a-- Categorie " et là? on prolonge tout simplement? " Categorie --a-- Vetement ou Cd ou ... " ? )

    Je suis sur que ça doit pas etre des plus compliqué, mais je sais pas pourquoi je me prend la tete la dessus et je tourne en rond.
    Merci de votre aide.
    Et si vous avez des exemples à me donner je suis preneur... merci encore.

  2. #2
    Membre actif Avatar de SmileSoft
    Inscrit en
    Mars 2008
    Messages
    436
    Détails du profil
    Informations forums :
    Inscription : Mars 2008
    Messages : 436
    Points : 214
    Points
    214
    Par défaut
    salut
    Citation Envoyé par straitch Voir le message
    Et quelle type de realtion les relie? (au debut c'etait simple " Article --a-- Categorie " et là? on prolonge tout simplement? " Categorie --a-- Vetement ou Cd ou ... " ? )
    utiliser la notion d'héritage avec l'entité mère catégorie et les entités fils Vetement, CD, livre...etc, voilà un petit exemple dans la faq
    Un thésard a souvent un problème de motivation jusqu'au moment où il aura un problème de temps....

  3. #3
    Membre à l'essai
    Inscrit en
    Août 2009
    Messages
    26
    Détails du profil
    Informations forums :
    Inscription : Août 2009
    Messages : 26
    Points : 24
    Points
    24
    Par défaut maintenance facile
    Je crois que le plus dur n'est pas de trouver une base de données simple mais c'est de concevoir une base qui se maintient facilement. Par exemple avec l'héritage proposé dans le message précédent, il est facile d'ajouter dans le fufur une nouvelle catégorie.

  4. #4
    Modérateur

    Avatar de CinePhil
    Homme Profil pro
    Ingénieur d'études en informatique
    Inscrit en
    Août 2006
    Messages
    16 799
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur d'études en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2006
    Messages : 16 799
    Points : 34 031
    Points
    34 031
    Billets dans le blog
    14
    Par défaut
    L'héritage est une possibilité mais quand il y a beaucoup de catégories, ça peut devenir très lourd.

    L'autre possibilité est d'associer des propriétés aux différentes catégories.

    Article -1,1----Catégoriser----0,n- Catégorie -1,n----Avoir----0,n- Propriété
    |-------------------------------------1,n----Avoir----0,n-------------------------------|

    Il faut prévoir une contrainte d'inclusion pour ne pas affecter de propriété à un article qui ne soit pas une propriété afférente à sa catégorie.

    Ce qui donnerait par exemple les tables :
    Propriété (P_Id, P_Libelle, P_ValeurDefaut)
    Categorie (C_Id, C_Libelle)
    Propriete_Categorie (PC_IdPropriete, PC_IdCategorie)
    Article (A_Id, A_IdCategorie, A_Nom)
    Propriete_Article (PA_IdPropriete, PA_IdArticle, PA_Valeur)

    Aucun souci là non plus pour ajouter de nouvelles catégories mais sans modifier le modèle de données et avantage de ne pas modifier le modèle de données pour ajouter des propriétés aux catégories et aux articles.
    Philippe Leménager. Ingénieur d'étude à l'École Nationale Supérieure de Formation de l'Enseignement Agricole. Autoentrepreneur.
    Mon ancien blog sur la conception des BDD, le langage SQL, le PHP... et mon nouveau blog sur les mêmes sujets.
    « Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément ». (Nicolas Boileau)
    À la maison comme au bureau, j'utilise la suite Linux Mageïa !

Discussions similaires

  1. Réponses: 7
    Dernier message: 27/06/2006, 20h16
  2. Réponses: 2
    Dernier message: 20/06/2006, 13h43
  3. Réponses: 9
    Dernier message: 03/03/2006, 10h02
  4. comment gérer le type HANDLE sous linux?
    Par poune dans le forum Autres éditeurs
    Réponses: 2
    Dernier message: 11/06/2004, 11h12

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