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:
Considérez-vous cela comme architecturalement correct? Ou bien cette technique est à proscrire? et pourquoi?
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;
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:
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.
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 .....
Bref! j'attends vos avis sur ce sujet.
Merci.
Partager