c# – 具有存储库模式的域模型
我有一个对象:图书馆
一个图书馆可以有多本书籍,CD和论文.每个类都有Id,Name和Price属性,但具有Address属性的Library类除外. 我想创建Repository模式来抽象从上面的层存储数据的位置.现在,数据存储在xml文件中. <library> <books></books> <cds></cds> <papers></papers </library> 后来我们考虑将其存储在数据库中.然后我们将有一个图书馆桌子,一张书桌,一张CD桌和一张纸桌. 用户在屏幕上创建一个库对象,然后在屏幕上创建书籍,CD和纸张. 然后他点击了Save.此时,我想获取新创建的库对象并将其保存为XML,因此我想拥有Repository并使用依赖注入,我将在上面的层中注入xml存储库的实现,以便将数据存储到正确的位置.我可以序列化Library对象并获取xml并调用简单的Save方法来保存库对象. 但是想象一下,我将XMLRepository替换为DatabaseRepository. 在这种情况下,我希望上面的其他层保持不变.我希望LibraryRepository.Save()能够注意它是否需要使用XML或CSV或DB. 世界各地的每个人都说Repository类应该只有一个责任. 此外,每个库对象都有多个Books对象.我不想使用for循环并浏览LibraryRepository.Save方法中的每本书. 我不确定如何创建我的域模型并调用Library Save()方法. 请指导. 解决方法
由于存储库是BL的持久性抽象,因此使用存储库接口.
每个存储库实现都应该将对象结构映射到数据存储,或使用特定的映射器. BL / Service类可以通过接口使用存储库,而无需了解特定存储库的内部实现. 所以你有类似的东西 class LibraryService { public LibraryService (ILibraryRepository repo) {} public DoSomeWork(somedata) { Library lib = repo.Load(somedata.libid); .... repo.Save(lib); } } 和几个实现 class DBLibraryRepository : ILibraryRepository { public Save(Library lib) { //hibernate session //and you'll have mapping defined for all entities //and relations between library and stuff,so books are saved automatically _session.Save(lib) } } class XMLLibraryRepository : ILibraryRepository { public Save(Library lib) { //serialized does all the work,so no additional loops here var xml = Serialize(lib); SaveToFile(xml); } } class CSVLibraryRepository : ILibraryRepository { public Save(Library lib) { //for example,save library to lib.csv,books - to books.csv. //add mappers to do real work,but we'd take care of separation //of books and library manually. // (in case of ORM - it has own mappers,// for XML - serializator is mapper itself) var data = LibraryCSVDataMapper.Map(lib); data.Save(); foreach(var book in lib.Books){ data = BookCSVDataMapper.Map(book); data.Save(); } } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |