在 DDD 的上下文中,总是说存储库只能查询聚合根。聚合根然后授予对聚合中其他实体的访问权限。但是,对聚合中的实体的查询是如何建模的?
假设 Orders 聚合的情况。订单是根并具有详细行列表,这些行引用产品(这是另一个聚合的根)并具有其他属性,例如数量
现在,假设我需要列出或订购引用特定产品的行,以生成可供各种服务使用的报告,例如计算产品订单请求的平均项目数。
搜索每个 Oder,然后列出所有行并选择我感兴趣的行,听起来不切实际。Orders 存储库中的 getLinesByProduct() 听起来更方便,但会将 Lines 暴露在 Aggregate 之外。
如何建模此查询?
也许问题是我正在查询我的命令模型,我应该有一个(非规范化的)查询模型,其中详细信息行是具有所有需要信息的实体?