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

C# Discussion :

Conseil architecture DAL sans Entity Framework


Sujet :

C#

  1. #1
    Membre éclairé Avatar de touftouf57
    Profil pro
    Développeur .NET
    Inscrit en
    Décembre 2007
    Messages
    362
    Détails du profil
    Informations personnelles :
    Âge : 47
    Localisation : France, Moselle (Lorraine)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2007
    Messages : 362
    Par défaut Conseil architecture DAL sans Entity Framework
    Bonjour,

    Je cherche un tutoriel avancé parce que sur le web je ne trouve pas ce que je recherche.

    Je voudrais chargé des objets depuis ma base de données. Je voulais utiliser Entity framework car avec les règles de navigation, il est capable de charger les autres objets dépendant de l'objet chargé. Par exemple: Une commande avec ses lignes de commande.

    Cependant, pour pouvoir définir ces règles de navigation avec EF, il faut que les relations de la base de données soient cohérentes. C'est à dire que les clés étrangères pointent sur des clés primaires.

    Mais dans ma base, ce n'est pas le cas. Je précise que je ne peux pas changer la structure de la base. Il faut que je fasse avec. Donc pas de règles de navigation définissable avec EF.

    J'utilise toujours EF, pour charger mes objets, mais les dépendances ne le sont pas.

    J'ai créé des DAO, qui vont chacune me lire les données d'une table de la base.

    J'ai aussi créé un "DAOManager" qui centralise toute les DAO.

    Ainsi, lorsque je charge une Commande j’exécute l'instruction suivante:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Commande commande = new Commande();
    ......//remplissage des données propres à la commande
    DaoManager.GetLignesCommande(commande.Numero);
    ....
    return commande;
    Considérez-vous cela comme architecturalement correct? Ou bien cette technique est à proscrire? et pourquoi?

    Je m'étais demandé s'il ne serait pas mieux de "charger" toutes les collections nécessaire depuis la base puis de faire faire une correspondance de cette façon:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    List<Commande> commande = daoCommande.GetAll();
    List<LigneCommande> lignes = daoLigneCommande.GetAll();
    commandeFiller.FaitCorrespondre(commandes,lignes); //Méthode qui ajoute toutes les lignes d'une même commande à la collection de ligne de la commande
    .....
    Je tiens à préciser qu'actuellement les données proviennent d'une base de données, mais plus tard cela pourrait très bien être des fichiers (xml, plat, excel,.....). Et qu'il ne faudrait pas que je recode ou duplique trop de choses.

    Bref! j'attends vos avis sur ce sujet.

    Merci.

  2. #2
    Membre éclairé Avatar de dfiad77pro
    Homme Profil pro
    Responsable Architecture logicielle
    Inscrit en
    Décembre 2008
    Messages
    544
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Responsable Architecture logicielle
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2008
    Messages : 544
    Par défaut
    Personnellement je le ferait en entity framework avec template T4, et j'étendrai ce modelé afin d'implémenter un 'loading' et un modèle d'objets sérialisables.


    Cela dit attention, si tu charge trop de données pour faire ta transformation en modèle objet ça risque de bouffer pas mal de mémoire

Discussions similaires

  1. Entity Framework v2 sans Linq
    Par 0redd dans le forum Accès aux données
    Réponses: 7
    Dernier message: 09/08/2010, 08h16
  2. Architecture : Silverlight - WCF - Entity Framework
    Par darkfrag dans le forum Silverlight
    Réponses: 6
    Dernier message: 02/12/2009, 17h52
  3. Entity Framework et architecture
    Par kendras dans le forum ASP.NET
    Réponses: 37
    Dernier message: 15/11/2009, 16h10
  4. Réponses: 2
    Dernier message: 03/04/2009, 16h31
  5. Réponses: 3
    Dernier message: 18/03/2008, 09h45

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