【发布时间】:2012-04-01 18:33:27
【问题描述】:
我刚开始学习领域驱动设计,最让我困惑的几件事之一是如何确定哪个应该是实体,哪个应该是值对象
我知道要确定实体/值对象,我们需要基于领域上下文,在一种情况下,一个领域对象可以是实体,在另一种情况下,它可以是值对象,但还是有一些情况我可以'决定
。地址 - 在客户管理应用程序的上下文中(比如说一个管理客户、添加/删除/更改客户状态等的应用程序),地址显然是价值对象,因为在这里我们不需要区分一个地址和另一个地址, 2 个客户可以有相同的地址 - 另一方面,在在线预订应用程序的上下文中,我可以说地址是一个实体吗?因为现在我们需要通过账单地址来区分客户(暂时忽略具有相同地址的案例 2 客户)
对我来说,地址本身就是独一无二的,所以它肯定已经有了身份。所以域对象的身份不会决定它是实体还是值对象,如果是,那么选择的关键因素是什么?
另一个例子,我有一个应用程序列出了一个国家/地区的多个地区,用户可以选择一个地区,然后找到该地区符合其搜索条件的所有餐厅。在这种情况下,区域是值对象还是实体?目前我认为它更多的是在一个实体上,但仍然不是很确定。每个区域也都是独一无二的
我不确定我的问题是否清楚,我尽力解释我目前的想法
【问题讨论】:
标签: object dns domain-driven-design entity