阿里高级技术员:DDD中实体与值对象是干什么的

实体值对象的含义

我们前面已经讲过领域的概念, 今天来讲讲实体, 实体是我们进行设计领域模型时的基础单元, 与之有关的是值对象, 接下来先梳理一下实体以及值对象的含义,然后讲讲他们俩的关系, 希望通过这篇文章能让你区分开与传统架构中实体的区别, 对领域模型中的实体有进一步的了解。

实体

实体这个概念在传统微服务中也有涉及, 在传统技术中, 实体一般是指实体类, 也就是数据库中的表格, 但是在领域模型中实体与传统架构中的实体有类似的地方但是不完全一样, 在DDD中, 实体的定义是: 实体拥有唯一标识符, 且标识符在经历过各种状态变更后仍能保持一致。对这些对象而言, 重要的不是其属性,而是其延续性和标识,对象的延续性和标识会跨越甚至超出软件的生命周期。下面举一些例子:

实体的业务形态

在 DDD 不同的设计过程中,实体的形态是不同的。在战略设计时,实体是领域模型的一个重要对象。领域模型中的实体是多个属性、操作或行为的载体。到这儿是不是就有一点感觉了, 我们通常的实体中一般不会有行为以及载体, 但是领域模型中的实体会有行为以及载体在, 事件风暴中,我们可以根据命令、操作或者事件,找出产生这些行为的业务实体对象,进而按照一定的业务规则将依存度高和业务关联紧密的多个实体对象和值对象进行聚类,形成聚合。可以这么理解,实体和值对象是组成领域模型的基础单元。

实体代码形态

在代码模型中,实体的表现形式是实体类,这个类包含了实体的属性方法,通过这些方法实现实体自身的业务逻辑。在 DDD 里,这些实体类通常采用充血模型,与这个实体相关的所有业务逻辑都在实体类的方法中实现,跨多个实体的领域逻辑则在领域服务中实现。

充血模型和贫血模型, 其实就是一个相对的概念, 在我们之前的MVC架构设计中, 一般数据放在数据层, 也就是实体中只包含属性, 对应的行为放在服务层, 这种实体不包含任何行为只包含属性的模型称之为贫血模型, 而充血模型就是实体中包含属性与行为。

实体运行时态

实体以 DO(领域对象)的形式存在,每个实体对象都有唯一的 ID。我们可以对一个实体对象进行多次修改,修改后的数据和原来的数据可能会大不相同。但是,由于它们拥有相同的 ID,它们依然是同一个实体。比如商品是商品上下文的一个实体,通过唯一的商品 ID 来标识,不管这个商品的数据如何变化,商品的 ID 一直保持不变,它始终是同一个商品。

实体数据库形态

与传统数据模型设计优先不同,DDD 是先构建领域模型,针对实际业务场景构建实体对象和行为,再将实体对象映射到数据持久化对象。在领域模型映射到数据模型时,一个实体可能对应 0 个、1 个或者多个数据库持久化对象。大多数情况下实体与持久化对象是一对一。在某些场景中,有些实体只是暂驻静态内存的一个运行态实体,它不需要持久化。比如,基于多个价格配置数据计算后生成的

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值