简述Hibernate两种方法的实现

开发 后端
实现Hibernate equals()/HibernatehashCode()最显而易见的方法是比较两个对象标识符的值。如果值相同,则两个对象对应于数据库的同一行,因此它们是相等的(如果都被添加到 Set,则在Set中只有一个元素)。

Hibernate有很多方法,每一种方法都有自己实现的过程,这里详述Hibernate两种方法的实现Hibernate equals()和Hibernate hashCode()。

实现Hibernate equals()和hashCode()如果你有如下需求,你必须重载 equals() 和 hashCode()方法:

想把持久类的实例放入Set中(当表示多值关联时,推荐这么做)

想重用脱管实例

Hibernate保证,仅在特定会话范围内,持久化标识(数据库的行)和Java标识是等价的。因此,一旦 我们混合了从不同会话中获取的实例,如果希望Set有明确的语义,就必 须实现equals() 和hashCode()。

实现Hibernate equals()/HibernatehashCode()最显而易见的方法是比较两个对象标识符的值。如果值相同,则两个对象对应于数据库的同一行,因此它们是相等的(如果都被添加到 Set,则在Set中只有一个元素)。

不幸的是,对生成的标识不能 使用这种方法。Hibernate仅对那些持久化对象赋标识值,一个新创建的实例将不会有任何标识值。此外, 如果一个实例没有被保存(unsaved),并且它当前正在一个Set中,保存它将会给这个对象 赋一个标识值。

如果Hibernate equals() 和Hibernate hashCode()是基于标识值 实现的,则其哈希码将会改变,这违反了Set的契约。建议去Hibernate的站点阅读关于这个 问题的全部讨论。

注意:这不是Hibernate的问题,而是一般的Java对象标识和Java对象等价的语义问题。

我们建议使用业务键值相等(Business key equality)来实现equals() 和 hashCode()。业务键值相等的意思是,equals()方法 仅仅比较形成业务键的属性,它能在现实世界里标识我们的实例(是一个自然的候选码)。

  1. public class Cat {  
  2.  
  3.     ...  
  4.     public boolean equals(Object other) {  
  5.         if (this == other) return true;  
  6.         if ( !(other instanceof Cat) ) return false;  
  7.  
  8.         final Cat cat = (Cat) other;  
  9.  
  10.         if ( !cat.getLitterId().equals( getLitterId() ) ) return false;  
  11.         if ( !cat.getMother().equals( getMother() ) ) return false;  
  12.  
  13.         return true;  
  14.     }  
  15.  
  16.     public int hashCode() {  
  17.         int result;  
  18.         result = getMother().hashCode();  
  19.         result = 29 * result + getLitterId();  
  20.         return result;  
  21.     }  
  22.  

注意:

业务键不必像数据库的主键那样固定不变。对业务键而言,不可变或唯一的属性是不错的选择。

【编辑推荐】

  1. 简述Hibernate中加载并存储对象
  2. Hibernate传播性持久化攻略
  3. 深入了解Hibernate自动状态检测
  4. 解读Hibernate高级集合映射
  5. Hinerbate单端关联代理颇析
责任编辑:仲衡 来源: javanb
相关推荐

2010-09-07 11:18:10

2010-07-26 15:42:34

Perl模块

2011-07-14 17:50:50

domino数据库

2010-08-04 17:41:52

挂载NFS

2010-08-03 13:53:47

Flex+Java配置

2009-04-21 11:23:56

Oraclespool比较

2010-11-24 14:36:25

修复mysql表

2011-03-30 17:04:24

MySQL添加用户

2010-04-13 09:50:44

Oracle跟踪

2024-01-02 11:45:00

读取requestmap

2009-08-05 15:54:49

Web Service

2009-11-03 16:20:16

VB.NET文本框

2010-02-06 14:35:36

ibmdwRUP迭代

2009-06-18 11:09:42

2010-11-12 11:44:37

SQL Server删

2010-09-09 19:53:50

2020-09-16 18:27:36

Linux方法IP地址

2019-09-15 17:35:28

Wireshark解密HTTPS

2009-08-05 13:34:18

C#日期相减

2010-11-10 13:22:41

SQL Server备
点赞
收藏

51CTO技术栈公众号