创建一个Java对象时,JVM会为这个对象分配一个内存空间,只要这个对象被引用变量引用,就一直存在于内存中,如果一个对象不被任何引用变量引用,就结束生命周期。Java集合(List、Map、Set)存放的是Java对象的引用,当向集合中添加一个对象时,其实是把这个对象的引用添加到集合中。因此集合中含有的对象生命周期一直存在。
理解Session的缓存:
在Session接口的实现中定义一系列的Java集合,这些集合构成了Session的缓存。
Session缓存的作用:1、减少访问数据库的频率,可以提高数据库访问的性能。2、保证缓存中的对象与数据库中的相关记录保持同步。3、当缓存中的持久化对象(位于缓存中的对象)之间存在循环关联关系时,Sessioin会保证不出现访问对象的死循环。
在Hibernate应用中Java对象的状态:
临时状态(transient):刚用new语句创建,还没有被持久化,不处于Session的缓存中。处于临时状态的Java对象称为临时对象。
持久化状态(persistent):已经被持久化,加入到Session的缓存中。处于持久化状态的Java对象称为持久化对象。
游离状态(detached):已经被持久化,但不再处于Session的缓存中。处于游离状态的Java对象称为游离对象。
Java对象:开始生命周期——》临时状态——》持久化状态——》游离状态——》结束生命周期
Session的保存、更新、删除、查询方法:
1、Session的save()方法
session.save(customer);完成的操作:
(1)把Customer对象加载到缓存中,使它变为持久化对象。
(2)选用映射文件指定的标识符生成器为持久化对象分配唯一的OID。Customer.hbm.xml文件中<id>元素的<generator>子元素指定标识符生成器。
(3)计划执行一个insert语句,把Customer对象当前的属性值组装到insert语句中。
insert into CUSTOMERS(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 CUSTOMERS set NAME="Tom", ...... where ID=1
如果希望Session仅当修改了Customer对象的属性时,才执行update语句,可把映射文件Customer.hbm.xml中<class>元素的"select-before-update"设为true(该属性默认为false)
<class name="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("from Customer as c where c.id>8");
级联操纵对象图
在对象-关系关联映射文件中,用于映射持久化类之间关联关系的元素<set>、<many-to-one>、<one-to-one>有cascade属性,用于指定如何操纵与当前对象关联的其他对象。
cascade属性可选值:none、save-update、delete、all、delete-orphan、all-delete-orphan
Hibernate与触发器协同工作
能激发触发器运行的事件:
插入(insert)记录事件、更新(update)记录事件、删除(delete)记录事件
利用拦截器(Interceptor)生成审计日志
用户定义的拦截器必须实现org.hibernate.Interceptor接口。
Interceptor对象有两种存放方式:
SessionFactory.openSession(Interceptor):为每个Session实例分配一个Interceptor实例,这个实例存放在Session范围内。
Configuration.setInterceptor(Interceptor):为SessionFactory实例分配一个Interceptor实例,这个实例存放在SessionFactory范围内,被所有Session实例共享。
操纵持久化对象
public final
的方法。
![](http://hi.csdn.net/attachment/201107/29/0_1311931731pQZ7.gif)
Query query = session.createQuery("from User as u where u.age > ? and u.name like ?");
query.setInteger(0, 25);
query.setString(1, "%a%");
List list = query.list();
|
Query query = session.createQuery("from User as u where u.age > :minAge and u.name like likeName");
query.setInteger("minAge", 25);
query.setString("likeName", "%a%");
List list = query.list();
|
......
<
hibernate-mapping
>
<
class
name
=
"org.qiujy.demo.User"
table
=
"user"
>
<
id
name
=
"id"
column
=
"id"
type
=
"java.lang.Integer"
>
<
generator
class
=
"native"
/>
</
id
>
<
property
name
=
"name"
column
=
"name"
type
=
"java.lang.String"
/>
<
property
name
=
"age"
column
=
"age"
type
=
"java.lang.Integer"
/>
</
class
>
<query name=
"queryUserByAgeAndName">
<![CDATA[
from User as u where u.age >:minAge and u.name like :likeName
]]>
</query>
</
hibernate-mapping
>
|
Query query = session.getNamedQuery(
"queryUserByAgeAndName");
query.setInteger("minAge", 25);
query.setString("likeName", "%a%");
List list = query.list();
|