- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我在不使用 ORM 的 .NET C# 应用程序中使用存储库模式。但是我遇到的问题是如何填充实体的一对多列表属性。例如如果客户有一个订单列表,即如果 Customer 类有一个名为 Orders 的 List 属性,而我的存储库有一个名为 GetCustomerById 的方法,那么呢?
这也引发了对更改跟踪、删除等功能的疑问?所以我认为最终结果是我可以在没有 ORM 的情况下进行 DDD 吗?
但现在我只对在我的域实体中延迟加载列表属性感兴趣?有什么想法吗?
纳比尔
我假设对于没有在领域驱动设计中使用 ORM 的人来说,这是一个非常普遍的问题?有什么想法吗?
最佳答案
can I do DDD without ORM ?
是的,但是 ORM 简化了事情。
老实说,我认为您的问题与您是否需要 ORM 无关 - 这是您对数据而不是行为的过多思考,而行为是 DDD 成功的关键。就数据模型而言,大多数实体都会以某种形式与大多数其他实体建立关联,从这个角度来看,您可以遍历整个模型。这就是您的客户和订单的样子,也许也是您认为需要延迟加载的原因。但是您需要使用聚合将这些关系分解为行为组。
例如,为什么要为客户聚合建模以包含订单列表?如果答案是“因为客户可以有订单”,那么我不确定您是否采用 DDD 的思维方式。
有什么行为要求客户有订单 list ?当您更多地考虑域的行为(即在什么时候需要什么数据)时,您可以根据用例对聚合进行建模,事情变得更加清晰和容易,因为您只更改一小部分对象的跟踪在聚合边界。
我怀疑 Customer 应该是一个没有订单列表的单独聚合,而 Order 应该是一个包含订单行列表的聚合。如果您需要对客户的每个订单执行操作,请使用 orderRepository.GetOrdersForCustomer(customerID);进行更改,然后使用 orderRespository.Save(order);
关于不使用 ORM 的更改跟踪,您可以通过多种方式执行此操作,例如,订单聚合可以引发订单存储库正在监听的已删除订单行的事件。当工作单元完成时,这些可以被删除。或者稍微不那么优雅的方法是维护已删除的列表,即您的存储库显然可以读取的 order.DeletedOrderLines。
总结:
编辑以回应评论:
我认为我不会为订单行实现延迟加载。您可能在不需要订单行的情况下对订单执行哪些操作?我怀疑的不多。
但是,当 DDD 的“规则”似乎没有意义时,我不会将其局限在其中,所以...不需要填充订单行的对象 AND 通常有大量订单行与订单相关联(两者都必须为真,我才会认为这是一个问题)然后我会这样做:
在订单对象中有这个私有(private)字段:
private Func<Guid, IList<OrderLine>> _lazilyGetOrderLines;
将由订单存储库传递给创建时的订单:
Order order = new Order(this.GetOrderLines);
这是 OrderRepository 上的私有(private)方法:
private IList<OrderLine> GetOrderLines(Guid orderId)
{
//DAL Code here
}
然后在订单行属性中可能如下所示:
public IEnumberable<OrderLine> OrderLines
{
get
{
if (_orderLines == null)
_orderLines = _lazilyGetOrderLines(this.OrderId);
return _orderLines;
}
}
编辑2
我发现这篇博文与我的解决方案类似,但更优雅:
http://thinkbeforecoding.com/post/2009/02/07/Lazy-load-and-persistence-ignorance
关于c# - 没有 ORM 的存储库模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5017969/
请提及(大)ORM 和微 ORM 之间的区别。与大型 ORM 相比,微型 ORM 有何优势?例如。 Entity Framework ORM 和 dapper micro ORM 之间的区别。 最佳答
我有一个名为 User 的模型。我可以从 User 模型扩展另一个模型 Admin/mod 吗?我找到了续集文档,但我没有找到 最佳答案 是的,查看 Associations documentatio
你对数据访问层有什么建议?使用 Entity Framework 和 Hibernate OR 代码生成器(如 Subsonic、.netTiers、T4 等)等 ORM? 最佳答案 对我来说,这很简
我编写了一个代码生成器,它为给定的 SQL Server/CE 数据库生成 POCO 和存储库。没什么花哨的,只有使用经典 ADO.Net 的简单 CRUD 程序。我的问题是,为什么我应该使用像 L2
我扩展了Android.Application类,以便保持状态(将应用程序用作单例)。 但是,我现在想使用Sugar ORM库简化我的数据库访问,但是Sugar文档(http://satyan.git
我正在阅读 OOP 设计模式和框架设计,发现自己对术语 ORM 和持久性框架之间的区别有点不确定。 ORM 是 PF 的一种吗?您可以期待两者有哪些不同的功能? 最佳答案 我将 ORM 定义为将任何数
在 Jboss EAP 7.0 中加载 orm 文件时,我遇到了以下问题,但它在 Weblogic 中工作。 原因:org.hibernate.boot.MappingException:无法解析显式
我一直在研究 Massive ORM。不要忘记,只是看,我还没有做任何编码。 我对保存交易数据的可能性感兴趣。我已经看到可以在一个事务中在同一个表中保存 20 行。但是当我想在单个交易中保存一个订单并
好的。我刚刚开始在我的 Coldfusion 应用程序中使用 ORM。到现在为止一切都很顺利。我遇到了这个障碍。我有这两张表: 这是我用来将数据加载到页面中的代码。 if 的第二部分是默认加载,第一部
我有可以分配许多类别的帖子。所以它是一个多对多的关系。 我想计算每个类别中有多少帖子(符合特定标准),然后对结果进行排序。 我有: Select ( Select count(post.id)
关闭。这个问题是opinion-based .它目前不接受答案。 想改善这个问题吗?更新问题,以便可以通过 editing this post 用事实和引文回答问题. 8年前关闭。 Improve t
我正在评估如何使用后端的分布式键/值存储来实现某些东西。我希望在支持对象模型的键/值之上有一个层,该对象模型类似于我从对象关系映射器中获得的模型。 任何人都可以指出其他人这样做的任何例子吗?我主要是在
我正在使用 kohana ORM 以便从数据库中获取一些结果。我的问题是:即使我查阅了文档,我也找不到只选择我感兴趣的列的方法。更明确地说,我有: $sale_stock = Model::facto
在 ORM 之前,如果我想显示规范化表的组合输出,我只需执行快速 CFQUERY,将表连接到我想要的字段并显示输出。我只是无法使用 ORM 来解决它。 例如这两个表: customers (id,
异步 ORM 的真正含义是什么?它与常规 ORM 的行为有何不同? 它可以用在什么地方? 最佳答案 这意味着对它的调用会立即返回(不会阻塞)。您会在稍后的某个时间点获得结果,很可能是由于回调触发。
虽然代码优先非常适合部署和开发,但我看不出如何在投入生产后以代码优先的方式插入对域模型所做的更改。 我如何处理我们在生产过程中积累的数据? 我是否应该手动将数据从 A 版架构迁移到 B 版架构?我是否
像学说(事件记录)和Xyster(数据映射器),有什么区别? 最佳答案 不同之处在于域对象与数据访问层的分离程度。使用 ActiveRecord,它是一个对象,这使它变得非常简单。特别是如果您的类一对
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我在 ColdFusion 中有一个持久实体,我需要更新一个属性 property name="createdDateTime" ormtype="date"; 到 property name="cr
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引起辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the he
我是一名优秀的程序员,十分优秀!