DDD,值对象和ORM

Arn*_*psa 13 identity domain-driven-design value-objects

值对象没有标识.ORM需要标识来更新数据库.

如何欺骗ORM?

(将值对象标记为内部将不起作用,因为ORM位于不同的程序集中并将其移动到同一程序集是不可接受的).

提前致谢.

Vij*_*tel 48

当Eric Evans谈到"实体有身份,Value Objects没有"时,他并不是在谈论数据库中的ID列 - 他在谈论身份作为一个概念.

VO没有概念身份.这并不意味着他们不应该有持久性身份.不要让持久性实施让您了解实体与VO.

在这里看我的帖子.


TWi*_*ars 5

就我个人而言,我在值对象中有 Id 字段 - 我将其视为值对象的另一个属性(例如名称、位置等)。

它可能不是真正的 DDD,但它对我有用。

  • 我认为这根本没有问题。埃里克·埃文(Eric Evan)让每个人都感到头晕目眩,因为很容易在不举例的情况下谈论概念。 (3认同)

Alb*_*bic 5

就我对DDD的理解而言,值对象只是一种对实体进行分区的方法.如果值对象应该与数据库中的ID一起存储,那么它不是值对象.

例:

域模型看起来像这样(C#):

public class Customer : Entity
{
    public Guid CustomerID { get; }

    public string LastName { get; set; }

    public Address HomeAddress { get; set; }
}

public class Address : ValueObject
{
    public string Street { get; set; }

    public string City { get; set; }

    public string ZipCode { get; set; }
}
Run Code Online (Sandbox Code Playgroud)

相应的数据库表看起来像这样(Pseudo-SQL):

CREATE TABLE Customers
(
    CustomerID,

    LastName,

    HomeAddress_Street,

    HomeAddress_City,

    HomeAddress_ZipCode,
)
Run Code Online (Sandbox Code Playgroud)

要将地址存储在单独的表中,您将使其成为具有ID的实体.

  • 但是如果你需要在表中保存地址,那么数据库需要一个id.仅仅因为数据库需要id并不意味着对象立即成为实体. (8认同)
  • 但是,域模型只是数据库的1:1,地址仍然可以是一个值对象,并且仍然有一个单独的表. (5认同)