作者:李东龙
上篇博客对数据持久化状态做了一些补充之后,下面来全面了解一下Session。看看Session都有那些作用和方法。
一、 缓存作用
a) 减少访问数据库的频率。
b) 保证缓存中的对象与数据库中的相关记录保持同步。
Session有两个方法:一个commit()事务提交方法,还有flush()刷新缓存方法,都有着清理缓存的作用。flush()进行缓存的清理,执行一系列的SQL语句,但不会提交事务。而commit()方法会先调用flush()方法,然后在提交事务。
二、 控制java对象持久化操作
1、Session的save()方法
session.save(customer);完成的操作:
(1) 把Customer对象加载到缓存中,使它变为持久化对象。
(2) 选用映射文件指定的标识符生成器为持久化对象分配唯一的OID。Customer.hbm.xml文件中<id>元素的<generator>子元素指定标识符生成器。
(3) 计划执行一个insert语句,把Customer对象当前的属性值组装到insert语句中。
insert intoCUSTOMERS(ID, NAME, ......) values(1, "Tom", ......)
save()方法并不立即执行SQL insert语句。只有当Session清理缓存时,才会执行SQL语句。
2、Session的update()方法
session.update(customer);完成的操作:
(1) 把Customer对象重新加入到Session缓存中,使它变为持久化对象。
(2) 计划执行一个update语句。Session只有在清理缓存时才会执行update语句,并且在执行时才会把Customer对象当前的属性值组装到update语句中。
(3) 只要通过update()方法使游离对象被一个Session关联,即使没有修改Customer对象的任何属性,Session在清理缓存时也会执行由update()方法计划的update语句。
update CUSTOMERSset NAME="Tom", ...... where ID=1
如果希望Session仅当修改了Customer对象的属性时,才执行update语句,可把映射文件Customer.hbm.xml中<class>元素的"select-before-update"设为true(该属性默认为false)
<classname="mypack.Customer" table="CUSTOMERS"select-before-update="true">
当Session清理缓存时,先执行一条select语句,然后比较Customer对象的属性是否和从数据库中检索出来的记录一致,只有在不一致时才执行update语句。
3、Session的saveOrUpdate()方法
如果传入的参数是临时对象,就调用save()方法;如果传入的参数是游离对象,就调用update()方法;如果传入的参数是持久化对象,那就直接返回。
Hibernate判断临时对象的条件:
(1)Java对象的OID取值为null
(2)Java对象具有version属性并且取值为null
(3)在映射文件中为<id>元素设置了unsaved-value属性,并且OID取值与unsaved-value属性只匹配
(4)在映射文件中为version属性设置了unsaved-value属性,并且version属性取值与unsaved-value属性值匹配
(5)自定义了Hibernate的Interceptor实现类,并且Interceptor的isUnsaved()方法返回Boolean.TRUE
4、Session的load()方法和get()方法
根据给定的OID从数据库中加载一个持久化对象。
当数据库中不存在与OID对应的记录时load()方法,返回ObjectNotFoundException异常get()方法,返null。
5、Session的delete()方法
如果传入的参数是持久化对象,Session就计划执行一个delete语句;如果传入的参数是游离对象,先使游离对象被Session关联,使它变为持久化对象,然后计划执行一个delete语句。
Session只有在清理缓存的时候才会执行delete语句。只有当调用Session的close()方法时,才会从Session的缓存中删除该对象。
session.delete(customer);
session.delete("fromCustomer as c where c.id>8");