小编典典

Hibernate映射中的值对象还是实体对象?

hibernate

我正在尝试设计一个非常简单的应用程序,并使自己与Hibernate的实体和值对象的定义(在Java Persistence with
Hibernate的第4章中定义)有些困惑。

我所拥有的是带有客户的应用程序,可以下订单(一对多关系)。这些订单中的每一个都有许多订单行(也是一对多)。现在,我认为客户具有身份(客户编号),订单(订单编号)也是如此,因此它们是实体对象吗?我的困惑来自订单行。

订单行具有数量,产品编号和价格。没有订单,订单行就不会存在,也没有自己的身份,因此我将其视为价值对象。但是我无法使订单行成为订单表的一部分,因为订单与其订单行之间存在一对多的关系。一对多关系如何与值对象的定义一起使用?从hibernate书中:

“值类型的对象没有数据库标识;它属于一个实体实例,并且其持久状态嵌入在拥有实体的表行中。值类型没有标识符或标识符属性”

如果有人能消除我的困惑,我将非常感激:)


阅读 335

收藏
2020-06-20

共1个答案

小编典典

Hibernate的文档区分了 Entity TypeValue Type ,而不是Value Object。

  • 实体类型的对象:具有自己的数据库身份
  • 值类型的对象:属于一个实体,并且其持久状态嵌入在拥有实体的表行中。值类型没有标识符或标识符属性。

据我所记得,这本书使用了一个示例,该示例具有address表示为单个String和一个user包含地址String 的对象:

  • 实现为值类型(通常意味着在数据库级别的同一表中的列),如果删除了用户,则其地址也删除了。没有用户,该地址将无法使用,也无法共享。

  • 地址被实现为实体类型(这可能意味着使用单独的表),这些地址将在没有用户的情况下独立存在,并且两个用户将能够共享同一地址。

在您的情况下,订单行不属于订单,其持久状态未嵌入订单行(没有意义),它具有自己的标识(由orderId和productId组成)。订单行绝对不是值类型,而是实体类型。

实际上,只要您考虑关联(一对一,一对多等),就肯定会操纵实体。

2020-06-20