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

Design Patterns Discussion :

Composite en db [Composite]


Sujet :

Design Patterns

  1. #1
    Membre du Club
    Homme Profil pro
    Directeur des systèmes d'information
    Inscrit en
    Février 2007
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Directeur des systèmes d'information

    Informations forums :
    Inscription : Février 2007
    Messages : 103
    Points : 64
    Points
    64
    Par défaut Composite en db
    Bonjour.

    Voici ce que j'essaie de transcrire dans ma bd :


    Et voici mon schéma relationnel :

    Element(id_elem);
    Article(#id_elem, titre,...);
    Categorie(#id_elem => id_cat, nom...);
    elem_cat(#id_elem, #id_cat, ordre...);

    Je veux éviter d'avoir une table qui ne contient qu'un seul champ.

    Des idées pour améliorer ça tout en restant souple ?

  2. #2
    Nip
    Nip est déconnecté
    Rédacteur

    Inscrit en
    Juin 2004
    Messages
    963
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 963
    Points : 1 076
    Points
    1 076
    Par défaut
    Pour etre sur de comprendre; qu'as tu represente? agregation ou composition? Tu parles de composition alors que tu representes une agregation.

    Sinon ta relation heritage/agregation (ou composition) me paraitrait plus que bizarre

  3. #3
    Membre du Club
    Homme Profil pro
    Directeur des systèmes d'information
    Inscrit en
    Février 2007
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Directeur des systèmes d'information

    Informations forums :
    Inscription : Février 2007
    Messages : 103
    Points : 64
    Points
    64
    Par défaut
    Oui en regardant de plus près, j'ai du confondre le losange plein (composition ?) et le losange creux (agrégation ?)

    C'est le design pattern composite que j'ai essayé de faire.

  4. #4
    Membre averti Avatar de Soutou
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    328
    Détails du profil
    Informations personnelles :
    Âge : 59
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 328
    Points : 378
    Points
    378
    Par défaut
    Citation Envoyé par hpavavar

    Element(id_elem);
    Article(#id_elem, titre,...);
    Categorie(#id_elem => id_cat, nom...);
    elem_cat(#id_elem, #id_cat, ordre...);

    Je veux éviter d'avoir une table qui ne contient qu'un seul champ.
    S'il n'existe pas d'élément qui ne soit Article ou Catégorie, la table Element n'a pas lieu d'exister.

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 206
    Points : 149
    Points
    149
    Par défaut
    Il essaie de faire cela : http://www.dofactory.com/Patterns/PatternComposite.aspx .

    Perso, j'utilise une base de données objets (db4o), donc je ne me pose pas la question du mappage. Mais la réponse m'interesse, je suis curieux de voir comment on stocke de manière efficace des objets composites dans une base relationnelle.

  6. #6
    Membre averti Avatar de Soutou
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    328
    Détails du profil
    Informations personnelles :
    Âge : 59
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 328
    Points : 378
    Points
    378
    Par défaut
    Comme ça :


  7. #7
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 206
    Points : 149
    Points
    149
    Par défaut
    Hmm il faudra que j'aille réviser les schémas de bases de données, j'ai du mal à interpréter le tien...

    Il y a 2 tables, ou ce sont des lignes d'une même tables ?

  8. #8
    Membre averti Avatar de Soutou
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    328
    Détails du profil
    Informations personnelles :
    Âge : 59
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 328
    Points : 378
    Points
    378
    Par défaut
    2 tables, prends comme exemple Composite : Immeuble et Composant : Appartement.

  9. #9
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 206
    Points : 149
    Points
    149
    Par défaut
    Je ne suis pas sûr de comprendre. Immeuble et appartement ne me semblent pas des exemples de design pattern Composite. Pour qu'ils le soient, il faudrait des appartements qui contiennent des immeubles.


    Voici un exemple de composite, tiré de l’excellent livre Head First sur les design patterns.


    Ce sont des ingrédients de recettes de cuisine. Il y a des ingrédients de base (deux sont représentés ici, la farine et le sel). Mais tu peux aussi avoir des ingrédients qui ont été préparés avant, par exemple une sauce vinaigrette. Cet ingrédient sera de la classe IngredientComposite, il contient une liste d’ingrédients, qui eux-mêmes peuvent être simples ou composites. C’est typiquement le genre de structure que l’on explore dans un TreeView.

    Donc, si je te comprends bien, il y aurait deux tables, une pour les ingrédients simples et l’autre pour les composites ? Et je me pose une autre question, comment est représenté l’héritage, dans ce cas-là ?

  10. #10
    Membre averti Avatar de Soutou
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    328
    Détails du profil
    Informations personnelles :
    Âge : 59
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 328
    Points : 378
    Points
    378
    Par défaut
    Citation Envoyé par Promeneur
    Je ne suis pas sûr de comprendre. Immeuble et appartement ne me semblent pas des exemples de design pattern Composite. Pour qu'ils le soient, il faudrait des appartements qui contiennent des immeubles.
    Je veux dire qu'un immeuble contient des appartements. Quand un immeuble disparaît, les apparts aussi doivent être détruits.

    Citation Envoyé par Promeneur
    Donc, si je te comprends bien, il y aurait deux tables, une pour les ingrédients simples et l’autre pour les composites ? Et je me pose une autre question, comment est représenté l’héritage, dans ce cas-là ?
    Pour l'héritage, plusieurs modèles relationnels peuvent être mis en oeuvre. Cela dépendra des propriétés contenues dans les classes et de l'existence d'objets dans les différents niveaux.

    Dans ton exemple, il manque les multiplicités mais on pourrait imaginer les relations suivantes si on considère qu'un ingrédient peut être mélangé à d'autres :

    Ingredient(id, ...)
    Farine(id#,...)
    Sel(id#,...)
    IngredientComposite(id1#,id2#)

  11. #11
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 206
    Points : 149
    Points
    149
    Par défaut
    Citation Envoyé par Soutou
    Je veux dire qu'un immeuble contient des appartements. Quand un immeuble disparaît, les apparts aussi doivent être détruits.
    J'ai l'impression que tu confonds "composition" et design pattern Objet Composite. Regarde les liens donnés, tu verras que c'est plus compliqué à gérer dans une base de données qu'une composition.

  12. #12
    Membre averti Avatar de Soutou
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    328
    Détails du profil
    Informations personnelles :
    Âge : 59
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 328
    Points : 378
    Points
    378
    Par défaut
    Dans l'exemple cité en URL, je pense qu'on peut mettre en oeuvre le modèle relationnel :

    Client(numcli, ...)
    Component(id,... numcli#)
    Composite(id#, idcomponent#...)
    Leaf(id#, ...)

    idcomponent référençeant le composite (père) d'un composant donné.

  13. #13
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 206
    Points : 149
    Points
    149
    Par défaut
    Citation Envoyé par Soutou
    Dans l'exemple cité en URL, je pense qu'on peut mettre en oeuvre le modèle relationnel :

    Client(numcli, ...)
    Component(id,... numcli#)
    Composite(id#, idcomponent#...)
    Leaf(id#, ...)

    idcomponent référençeant le composite (père) d'un composant donné.
    Hmm à priori il ne devrait pas y avoir de table Component, non ? Et un composite peut être référencé par un composite. Donc, tu aurais 3 tables, Client, composite et leaf ?

    En reprenant l'exemple de la recette, pour la recette du gabloufis aux niorks, on aurait (je parle en objets, pas en tables)

    une liste list<ingredient> qui contientrait les ingrédients suivants :

    - Farine
    - sel
    - Niork (composite contenant une list<ingredient>) :
    -------sucre
    -------frambroise
    -------lait
    -------Sauce royale (composite contenant une list<ingredient>) :
    -----------eau
    -----------sel
    -----------jus de poisson fermenté
    - levain

    Comme tu le vois, un comoosite contient une collection d'élements qui descendent du type abstrait ingrédeients et qui sont soit des leafs (comme sel ou levain) soit des composites (comme niork ou sauce royale).


    ah, bon appétit ...

  14. #14
    Membre averti Avatar de Soutou
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    328
    Détails du profil
    Informations personnelles :
    Âge : 59
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 328
    Points : 378
    Points
    378
    Par défaut
    C'est une structure hiérarchique qui n'est pas facile à manipuler avec SQL.

    Pour la recette du gabloufis aux niorks

    Component(id,... numcli#)
    Farine,...
    sel,...
    Niork ,...
    Sauce royale ,...
    levain,...

    Composite(id#, idcomponent#...)
    sucre , Niork
    frambroise, Niork
    lait, Niork
    Sauce royale , Niork

    eau, Sauce royale
    sel, Sauce royale
    jus de poisson fermenté, Sauce royale

    Sens-tu l'odeur du plat là?

  15. #15
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 206
    Points : 149
    Points
    149
    Par défaut
    heu, je n'ai pas faim, là...


    Donc 2 tables, une pour les ingrédients et une pour les ingrédients de composite, si je comprends bien, ou tout cela dans la meme table ?

  16. #16
    Membre du Club
    Homme Profil pro
    Directeur des systèmes d'information
    Inscrit en
    Février 2007
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Directeur des systèmes d'information

    Informations forums :
    Inscription : Février 2007
    Messages : 103
    Points : 64
    Points
    64
    Par défaut
    Au final voici ce que j'ai fais :

    Element:
    id_elem pk
    id_article rk
    id_cat rk
    (avec comme contrainte : une seule des clé externe doit être non nulle)

    Article:
    id_article pk
    titre....

    Categorie:
    id_cat pk
    nom categorie...

    Elem_Cat:
    id_elem rk
    id_cat rk
    (id_elem, id_cat) PK

    Ca marche assez bien ! J'ai toute la souplesse que je voulais: Ajouter un nouvelle entité qui hérite d'élément revient à créer une colonne dans la table élément.

    L'élément racine d'elem_cat est trouvable en cherchant la ligne d'elem_cat qui contient en même temps un id_cat et son id_elem correspondant.
    (Je me suis imposé de ne créer qu'une seule racine)

    Au niveau performance j'ai un soucis : lorsque je veux à partir d'un element, trouver sa catégorie mère, puis la grand-mère, puis... jusqu'a la racine.
    Ca m'oblige a faire une requête par niveau.

  17. #17
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2005
    Messages
    206
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2005
    Messages : 206
    Points : 149
    Points
    149
    Par défaut
    Citation Envoyé par hpavavar
    Ca marche assez bien ! J'ai toute la souplesse que je voulais: Ajouter un nouvelle entité qui hérite d'élément revient à créer une colonne dans la table élément.
    "Ajouter une nouvelle entité", c'est ajouter une nouvelle classe dans le modèle objet, pas une nouvelle donnée ?

  18. #18
    Membre du Club
    Homme Profil pro
    Directeur des systèmes d'information
    Inscrit en
    Février 2007
    Messages
    103
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Afghanistan

    Informations professionnelles :
    Activité : Directeur des systèmes d'information

    Informations forums :
    Inscription : Février 2007
    Messages : 103
    Points : 64
    Points
    64
    Par défaut
    Oui je l'entend sous le sens ajouter une nouvelle classe

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

Discussions similaires

  1. Réponses: 15
    Dernier message: 14/12/2004, 18h01
  2. [FLASH MX2004][AS2] Composition
    Par bolo dans le forum Flash
    Réponses: 9
    Dernier message: 10/12/2004, 16h53
  3. Aide sur la création d'un type simple (nom composite)
    Par testeur dans le forum PostgreSQL
    Réponses: 1
    Dernier message: 06/11/2004, 20h30
  4. clés composites
    Par Yuna dans le forum Administration
    Réponses: 12
    Dernier message: 08/01/2004, 09h14
  5. [WSAD] Composition visuelle d'une applet
    Par schum11 dans le forum Eclipse Java
    Réponses: 1
    Dernier message: 09/04/2003, 16h19

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