域驱动设计 – DDD:聚合根问题

前端之家收集整理的这篇文章主要介绍了域驱动设计 – DDD:聚合根问题前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
假设我有两个实体 – Foo和Bar。 Foo是一个聚合根,并包含栏。据我所知,这应该是这样的:
public class Foo{
    private readonly Bar Bar;
}

我想为用户提供功能,从定义的列表中选择条形码(并更改它)。

如果存储库应该仅用于聚合根,那意味着Bar实体将不会有存储库。

这导致问题 – Bar不能独立创建/更新,而不引用Foo。

这是否意味着酒吧应该有一个存储库,尽管没有Foo没有意义?

如果要从与Foo不相关联的条列表中进行选择,那么这不是聚合根。例如,您无法获取没有订单的OrderItem列表,因此这是单个聚合根(Order),但您可以获取要分配给OrderItems的产品列表,因此Product不是Order聚合根的一部分。

请注意,虽然OrderItem是Order聚合根的一部分,您仍然可以独立创建和更新它。但是,如果没有参考订单,您就无法获得。对于你的酒吧,即使它是Foo的一部分,你也可以得到每个(Foo.Bars)并使用它,或者做Foo.AddBar(新的Bar())。但是如果你需要得到没有Foo的List,Bar不是Foo聚合的一部分。它是一个单独的实体。

那么这就是我在这里看到DDD,但是我当然不是Eric Evans。

猜你在找的设计模式相关文章