如何解决当引用另一个有界上下文的实体时,应该使用实体还是值对象?
在我的域中,我有两个有界上下文identity
和management
。
在identity
受限制的上下文中,我拥有user
实体。和管理我有visitor
和manager
。 visitor
和manager
都有一些不同的属性,并且都引用了user
。
如果visitor
和manager
是实体,我可以使用用户ID作为其ID吗?我的意图是使用visitors/:userID
之类的api。
如果它们是值对象,那么我如何为每种类型的对象保留属性?
解决方法
当具有不同的有界上下文时,将它们隔离是很重要的,因为它们共享相同的无处不在的语言,但是每个上下文的含义是不同的。
完全有可能具有这种设计。例如,在您的有界上下文identity
中,您有一个值对象UserId
(最有可能)。它可以由不同的属性组成,但是为了简单起见,假设它只封装了String
。
然后,在您的management
有界上下文中,您可以在新类中使用值对象UserId
,但它特定于您的有界上下文。
然后,关于您的entities
visitor
和manager
:两者都是聚合根,因此它们都是entities
。它们只是您的聚合的入口点。它们是实体,但其ID是值对象UserId
。
您最终得到以下可能的代码:
public class Visitor {
private UserId id;
// some other attributes and domain method
}
public class Manager {
private UserId id;
// some other attributes and domain method
}
这是一个非常有限的示例,但总而言之,您有:
-
Identity
有界上下文:1个实体User
和1个VOUserId
-
Management
有界上下文:2个实体Visitor
Manager
和1个VOUserId
为进一步阅读,我建议该博客更深入地研究如何正确设计聚合:
- Vaugh Vernon - DDD Comunity - Effective aggregate design
- 还有这本书:实现域驱动设计,作者是 Vaugh Vernon
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。