-
aggreate:聚合对象,实体对象、值对象的协同组织,就是聚合对象。
典型的聚合结构:
示例:
假设我们在一个电商系统中有一个“订单(Order)”的业务场景,订单可以包含多个“订单项(OrderItem)”。订单是一个聚合根,负责管理订单项的添加、删除、数量调整等操作。订单项是订单的一部分,不能独立存在。
在这个例子中:
-
aggreate:聚合对象,实体对象、值对象的协同组织,就是聚合对象。聚合对象通过一个核心的实体,称为聚合根(Aggregate Root),对外部世界进行交互和访问。聚合根是该聚合的入口点,负责管理聚合内部所有的实体和值对象的生命周期、业务规则和行为。
-
实体和值对象的组合:聚合可以包含多个实体和值对象,聚合根是这些对象的唯一入口点。例如,一个
订单(Order)
聚合可以包含订单项(OrderItem)
,订单项
可以是一个实体,但它必须通过订单
来操作,而不能被直接操作。 -
只暴露聚合根:外部系统只能通过聚合根来访问和操作聚合内部的数据,这样可以避免数据不一致的情况。聚合根可以对聚合内部的实体和值对象执行操作。
-
Order
是聚合根,代表了整个订单聚合对象,它负责管理和操作订单项。 -
OrderItem
是订单中的子实体,不能独立存在,必须通过Order
来管理和操作。 -
外部系统只能通过
Order
(聚合根)来添加或移除OrderItem
,而不能直接操作OrderItem
。 -
entity:实体对象,大多数情况下,实体对象(Entity)与数据库持久化对象(PO)是1v1的关系,但也有为了封装一些属性信息,会出现1vn的关系。
-
valobj:值对象,通过对象属性值来识别的对象 。
-
entity和valobj的区别:entity往往都会有一个唯一标识表明,
-
student1(id=1,username="wanghao",password="123456")
-
student2(id=2,username="wanghao",password="123456")
-
由于有id进行区分所以这就是俩个不同的entity对象,
-
studentVO1(username="wanghao",password="123456")
-
studentVO2(username="wanghao",password="123456")
-
这是俩个相同的值对象
-
DTO(数据传输对象):主要用于在不同层之间传递数据。DTO是一个纯粹的数据容器,通常是可变的,不包含业务逻辑。它的作用是将数据从一个层传递到另一个层,比如从服务层传递到视图层。
-
比如,前端往后端传输数据时,如果是多个属性就会封装成一个DTO传输。
-
前端登录要传用户名和密码(username="wanghao",password="123456")往后端传输,后端就会用一个UserDTO去接收
-
po(持久化对象):也可以称为持久化实体。它是在软件开发中,尤其是在与数据库交互的场景中常用的术语。PO主要用于表示与数据库表结构对应的对象,能够将数据从数据库加载到内存中,并且可以持久化到数据库中。它通常与ORM(对象关系映射)框架配合使用,比如Hibernate、MyBatis等。
-
通常一个表就对应一个po实体