gpt4 book ai didi

c# - 如何在 DDD 实体中表示引用

转载 作者:行者123 更新时间:2023-11-30 18:04:15 26 4
gpt4 key购买 nike

我正在尝试掌握 DDD,我觉得我已经很好地掌握了实体、聚合、聚合根、存储库和值对象以及如何在代码中实际表示这些概念。

我仍在纠结的是如何在实际代码中表示引用(即不构成聚合的关系)。假设我有以下两个聚合

DISCUSSIONGROUP (entity, aggregate root)
+name: string
+ENTRY (entity)
+title: string
+message: string
+timestamp: date
+madeByUser: USER

USER (entity, aggregate root)
+name: string
+email: string
+memberOf: DISCUSSIONGROUP

用户可以是讨论组的成员,但用户实体不属于同一集合。然而,两者之间仍然存在关系(引用)。在查看实际代码时,我会实现聚合关系,例如(使用 C#):

interface IDiscussionGroup {
string Name { get; }
IList<IEntry> { get; }
...
}

即使用简单的 C# 引用。你会以相同的方式实现 DDD 引用(如上所述)吗,即:

interface IUser {
IDiscussionGroup MemberOf { get; }
...
}

是否应该使用其他结构来表示较弱的关系类型?

最佳答案

实际上这取决于您的要求。没有一种方法可以很好地完成它,但我要做的是使 DISCUSSIONGROUP 实体中的 madeByUser 属性成为一个 ValueObject。

为什么?因为在显示 DisscusionGroup 的条目时,我对要在条目上显示的用户的姓名和电子邮件很感兴趣。我不希望该用户在我的条目从数据库中删除后消失。如果 User 实体有更多的属性和行为,我对此不感兴趣,例如在显示用户信息时,ValueObject 就可以了。此外,您可以在多个条目之间共享该 VO,而无需为每个条目检索具体用户的实例。

另一方面,User 聚合是否在与 discussionGroup 相同的上下文中使用?我的意思是 DiscussionGroup 可以是一个上下文中的实体(例如在前台用例中)和用户管理后台中的值对象(我们对管理讨论组不感兴趣,而只对用户感兴趣,所以一个简单的有关讨论组的信息就足够了)。但是,您可能希望从 DiscussionGroup 实体到 User 实体的引用,或者在这种情况下也使 DiscussionGroup 成为 VO。您是否需要检索给定用户的所有讨论组和条目?或者您只需要一些可以嵌入到值对象中的信息?

如果我没有很好地回答您的问题,我很抱歉,但直接引用或仅在聚合之间使用某种共享 ID 或使用 VO 实际上取决于用例和行为 你必须实现。

如果我可以在不执行延迟加载和其他类似操作的情况下检索聚合中的所有数据,我个人会检查我是否定义了一个好的聚合边界。

也许其他人有不同的观点。

关于c# - 如何在 DDD 实体中表示引用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6369804/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com