DDD声明您应该只通过其聚合根访问实体.例如,假设你有一个聚合根X,它可能有很多子Y实体.现在,对于某些情况,您一次只关心这些Y实体的子集(可能您正在分页列表中显示它们或其他).
那么实现存储库是否可以,以便在这种情况下它返回一个不完整的聚合?IE浏览器.一个X对象谁只有Ys集合只包含我们感兴趣的Y实例而不是所有它们?例如,这可能导致X上的方法执行一些涉及Ys的计算不能按预期运行.
这或许表明有问题的Y实体应被视为提升为聚合根吗?
我目前的想法(在C#中)是利用LINQ的延迟执行,以便我的X对象具有IQueryable来表示它与Y的关系.这样,我可以通过过滤实现透明的延迟加载...但是让它工作使用ORM(在我的情况下Linq到Sql)可能有点棘手.
还有其他聪明的想法吗?
我认为具有很多子实体的聚合根是代码气味,或者如果你愿意的话,会有DDD气味.:-)一般来说,我看两个选项.
将您的聚合拆分为许多较小的聚合.这意味着我的原始设计不是最优的,我需要识别一些新的实体.
将您的域拆分为多个有界上下文.这意味着有一组特定的场景使用聚合中实体的公共子集,而有其他一组场景使用不同的子集.