Hibernate区分不同对象的方法

开发 后端
本文讲述了关系数据库、Java和Hibernate区分不同对象的方法。关系数据库按主键区分不同记录。Java语言按内存地址区别不同的对象。而Hibernate用对象标识符(OID)来区分不同对象。

1.关系数据库按主键区分不同记录。

  1. create table CUSTOMERS (ID int promary key not nullNAME varchar(15));  
  2.  
  3. insert into CUSTOMERS values(1, 'Tom');  
  4.  
  5. insert into CUSTOMERS values(3, 'Tom');  

2.Java语言按内存地址区别不同的对象。

  1. Customer c1 = new Customer("Tom");  
  2.  
  3. Customer c2 = new Customer("Tome");  
  4.  
  5. Customer c3 = c1;  
  6.  
  7. // c1 == c3 结果为true 
  8.  
  9. // c1 == c2 结果为false 

3.Hibernate用对象标识符(OID)来区分不同对象。

  1. Customer c1 = (Customer)session.load(Customer.classnew Long(1));  
  2.  
  3. Customer c2 = (Customer)session.load(Customer.classnew Long(1));  
  4.  
  5. Customer c3 = (Customer)session.load(Customer.classnew Long(3));  
  6.  
  7. // c1 == c2 结果为true  
  8.  
  9. // c1 == c3 结果为false  

以上程序中,三次调用了Session的load()方法,分别加载OID为1或3的Customer对象。以下是Hibernate三次加载Customer对象的流程。

(1)第一次加载OID为1的Customer对象时,先从数据库的CUSTOMERS表中查询ID为1的记录,再创建相应的Customer实例,把它保存在Session缓存中,最后把这个对象的引用赋值给变量c1。

(2)第二次加载OID为1的Customer对象时,直接把缓存中OID为1的Customer对象的引用赋值给c2,因为c1和c2引用同一个Customer对象。

(3)当加载OID为3的Customer对象时,由于在缓存中不存在这样的对象,所以必须再次到数据库中查询OID为3的记录,再创建相应的Customer实例,把它保存存在Session缓存中,最后把这个对象的引用赋值给变量c3。

【编辑推荐】

  1. Hibernate创建命名策略
  2. Hibernate的unsaved-value
  3. Hibernate中get和load方法的区别
  4. 项目添加Hibernate支持
  5. Hibernate查询语言HQL 八大要点


 

责任编辑:book05 来源: 百度博客
相关推荐

2009-06-30 16:41:12

Hibernate的事

2013-08-15 09:38:56

服务器虚拟化虚拟化

2012-02-08 14:01:18

HibernateJava

2012-02-08 14:24:35

HibernateJava

2009-09-23 10:14:10

Hibernate使用

2009-09-25 13:14:58

Hibernate C

2009-09-29 10:46:58

Hibernate领域

2009-06-26 16:33:09

saveOrUpdatHibernate

2009-06-26 16:34:50

delete()方法Hibernate S

2024-05-28 09:49:42

Python对象函数

2009-06-17 15:06:50

Hibernate实体

2009-09-23 13:26:10

Hibernate对象

2009-09-22 11:27:41

模型对象Hibernate

2010-09-15 15:39:03

CSS hack

2009-09-25 15:34:42

Hibernate关联

2009-09-23 09:47:23

Hibernate e

2009-06-12 15:09:01

Hibernate优化

2009-09-27 14:41:05

Hibernate I

2009-06-24 07:55:36

Hibernate不同SQL方言

2009-09-23 16:54:08

Hibernate修改
点赞
收藏

51CTO技术栈公众号