使用Entity Framework 4.1并尝试在上面创建一个存储库层作为测试.基本上我正在玩它以熟悉,因为我是Entity Framework和存储库模式的新手.我已经按照一些教程并创建了一个通用存储库.存储库的启动方式如下:
CentralDataRepositoryEntities CentralDataRepositoryEntities = new CentralDataRepositoryEntities();
Repository<Group> Rep = new Repository<Group>(CentralDataRepositoryEntities);
IEnumerable<Group> Groups = Rep.Get<Group>(g => g.JorMGroupId == 114);
Console.WriteLine(Group.Single());
Repository<Job> Rep1 = new Repository<Job>(CentralDataRepositoryEntities);
IEnumerable<Job> Jobs = Rep1.Get<Job>(j => j.jobId == 2138);
Console.WriteLine(Job.Single());
如果我不必每次都启动一个新的存储库,我更喜欢它.有没有办法可以创建存储库然后使用泛型方法?例如.:
Repository Rep = new Repository(CentralDataRepositoryEntities);
IEnumerable<Group> Groups = Rep.Get<Group>(g => g.JorMGroupId == 114);
IEnumerable<Job> Jobs = Rep.Get<Job>(j => j.jobId == 2138);
这是一个好主意吗?为什么要为每种类型创建一个单独的存储库,以及创建多个存储库时的性能如何?
最佳答案 拥有这样的存储库将违反
Single responsibility principle.单个存储库应该只负责管理单一类型的实体.
此通用存储库模式仅适用于简单方案.在某些情况下,您需要在存储库中为特定实体提供其他方法.