值对象如何存储在数据库中?

时间:2009-03-24 19:57:12

标签: domain-driven-design value-objects

我还没有看到任何示例,但我认为它们保存在数据库中的包含实体表中。

IE中。如果我有一个Person实体/聚合根和一个相应的Person表,如果它有一个名为Address的值对象,则地址值将保存在此Person表中!

对于我有其他实体(如公司等)拥有地址的域名,这是否有意义?

(我目前正在编写一个项目管理应用程序并尝试进入DDD)

3 个答案:

答案 0 :(得分:104)

由于您所描述的原因,可以将值对象存储在单独的表中。但是,我认为你是对实体与VO的误解 - 这不是与持久性相关的问题。

以下是一个例子:

假设公司都具有相同的邮件地址。哪些陈述确实有效?

  1. “如果我修改Company.Address,我想要 Person.Address自动获取 那些变化“
  2. “如果我修改Company.Address,它 不得影响Person.Address“
  3. 如果 1 为真,则地址应为 实体 ,因此拥有自己的表

    如果 2 为真,则地址应为 值对象 。它可以作为组件存储在父实体的表中,也可以拥有它自己的表(更好的数据库规范化)。

    正如您所看到的,地址的持久性与Entity / VO语义无关。

答案 1 :(得分:11)

大多数开发人员倾向于先在数据库中考虑其他事情。 DDD不知道如何处理持久性。这取决于存储库来处理它。您可以将其保存为xml,sql,文本文件等。实体/聚合/值对象是与域相关的概念。

Vijay Patel的解释非常完美。

答案 2 :(得分:2)

我开始以Eric Evans的书和优秀的dddsample Cargo项目为例学习DDD。 http://dddsample.sourceforge.net/

那么对于那些想要在域模型层中实现这种细微差别的代码实现差异的人(比如我),我会说:

我认为,overidded方法Equals或/和sameIdentityAs / SameValueAs(来自接口Entity和ValueObject)是它们表达式的位置。

这只是我的感受' :)

我认为这也很有趣:

http://martinfowler.com/bliki/ValueObject.html