为每个对象创建通用存储库与特定存储库的优势?

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (44)

我们正在开发ASP.NETMVC应用程序,现在正在构建存储库/服务类。我想知道创建一个通用的IRepository接口是否有任何主要的优势,所有的存储库都可以实现,而每个存储库都有自己独特的接口和一组方法。

public interface IRepository : IDisposable
{
    T[] GetAll<T>();
    T[] GetAll<T>(Expression<Func<T, bool>> filter);
    T GetSingle<T>(Expression<Func<T, bool>> filter);
    T GetSingle<T>(Expression<Func<T, bool>> filter, List<Expression<Func<T, object>>> subSelectors);
    void Delete<T>(T entity);
    void Add<T>(T entity);
    int SaveChanges();
    DbTransaction BeginTransaction();
}

每个存储库将实现这个接口,例如:

  • CustomerRepository:IRepository
  • ProductRepository:IRepository
  • 等等。

我们在以前的项目中所遵循的替代方案是:

public interface IInvoiceRepository : IDisposable
{
    EntityCollection<InvoiceEntity> GetAllInvoices(int accountId);
    EntityCollection<InvoiceEntity> GetAllInvoices(DateTime theDate);
    InvoiceEntity GetSingleInvoice(int id, bool doFetchRelated);
    InvoiceEntity GetSingleInvoice(DateTime invoiceDate, int accountId); //unique
    InvoiceEntity CreateInvoice();
    InvoiceLineEntity CreateInvoiceLine();
    void SaveChanges(InvoiceEntity); //handles inserts or updates
    void DeleteInvoice(InvoiceEntity);
    void DeleteInvoiceLine(InvoiceLineEntity);
}

在第二种情况下,表达式(LINQ或其他)将完全包含在Repository实现中,无论是谁实现服务,只要知道要调用哪个存储库函数即可。

我想我没有看到在服务类中编写所有表达式语法并传递到存储库的好处。这不意味着在许多情况下容易被复制LINQ代码吗?

例如,在我们以前的发票系统中,我们调用

InvoiceRepository.GetSingleInvoice(DateTime invoiceDate, int accountId)

从几个不同的服务(客户,发票,帐户等)。这似乎比在多个地方编写以下内容要干净得多:

rep.GetSingle(x => x.AccountId = someId && x.InvoiceDate = someDate.Date);

我发现使用特定方法的唯一缺点是,我们最终可能会得到许多GET的排列。函数,但这似乎仍然比将表达式逻辑向上推到服务类中更好。

我遗漏了什么?

提问于
用户回答回答于

但是与此同时,大部分的内容都是在你设计的时候出现的,我发现在开发我的模型时,建立一个通用的存储库并使用它,我可以非常快地得到一个应用程序,然后重构到更大的特异性,因为我发现有必要这样做。

因此,在这种情况下,我经常创建一个具有完整CRUD堆栈的通用IRepository,它使我能够快速地使用API,让人们玩w/UI,并行地进行集成和用户接受测试。然后,当我发现我需要关于回购等的特定查询时,我开始替换那个依赖关系w/如果需要的话,然后从那里开始。一个底层的实现很容易创建和使用(可能还可以挂钩到内存中的数据库或静态对象或模拟对象或其他任何东西)。

尽管如此,我最近开始做的是打破这种行为。因此,如果您为IDataFetcher、IDataUpdater、IDataInserter和IDataDeleter(例如)做了接口,可以通过接口混合和匹配来定义您的需求,然后有一些或所有的实现来处理它们,我仍然可以在构建应用程序时注入do-it-所有的实现。

热门问答

关于notebook文件导出cos桶报错的疑问?

腾讯智能钛AI开发者

腾讯云 · 智能钛产品团队 (已认证)

腾讯智能钛产品团队官方运营账号。分享产品最新动态,第一时间解答用户疑问。
推荐
这边看您从个人 COS 路径中导入数据到 Notebook ,那么您需要参照以下代码进行鉴权和数据导入。 获取密钥: import os import requests cred_url = os.environ["QCLOUD_CONTAINER_INSTANCE_CREDEN...... 展开详请

iOS实时音视频的SDK和Demo有没有Objective-C版本?

腾讯视频云-ZacharyTXLiteAVSDK技术支持
推荐
下载专业版和企业版的压缩包里面带的官方demo是Objective-C的,下载地址:https://cloud.tencent.com/document/product/647/32689 image.png ... 展开详请

请问小游戏联机对战引擎能在cocoscreater3d中运行吗?

无聊至极互联网重度用户
推荐
您好!非常感谢您的反馈,您的问题我们已经收到,小游戏联机对战引擎能兼容 crearor 3d。 因为 cocoscreator 近期会发布新版本,开发者可以非常便捷的在 crearor2d 的 ide 里面直接开通 mgobe 服务并上传实时服务器代码,所以我们更推荐您使用 cr...... 展开详请

腾讯会议API创建用户UserId 参数设置无效,没有主持人?

推荐
您好!非常感谢您的反馈,您的问题我们已经收到。 api创建的会议,没有主持人权限,请确认请求头中是否有带X-TC-Registered参数。 X-TC-Registered没带是不能获取到主持人身份的。 若解决中还存在其它问题,欢迎继续在社区反馈或【提交工单】,我们收到后会尽快处...... 展开详请

Android腾讯移动推送快速接入无法运行,tpnsplugin什么时候能修正此问题?

您好,给您造成不便深表歉意,TPNS 团队已经确认此问题,并将在近期排期更新插件以适配新版本 gradle 插件,还请您耐心等待。 目前您可以考虑降级 gradle 插件版本来继续使用 TPNS 快速集成插件,或参考 Android 接入指南:https://cloud.tenc...... 展开详请

windows(C++)版本的TRTC能不能支持xp?

腾讯视频云-ZacharyTXLiteAVSDK技术支持
推荐
不支持,最低支持WIndows 7,集成文档:https://cloud.tencent.com/document/product/647/32178 image.png ... 展开详请

所属标签

扫码关注云+社区

领取腾讯云代金券