快速了解Hibernate中的Session
hibernate中的session是一级缓存,可以理解为进程级(是线程吧)的缓存,在进程(是线程吧)运行期间一直存在。
session可以理解为一个可以操作数据库的对象,该对象中有操作数据库的方法。
在java里面,缓存通常是指java对象的属性占用的内存空间,通常是一些集合类型的属性。在session接口的实现类sessionimpl中定义了一系列的java集合,这些java集合就构成了session的缓存。
总的来说(我对session的理解):session是hibernate和db的中间人(一个对象),session中有两块东西或者说是功能
(1)操作数据库的方法
(2)session中有一些属性(集合之类的东西),通过这些属性来存储要发送给db的sql语言、缓存从db中已经查出来的数据等
session缓存
session缓存是由一系列的java集合构成的。当一个对象被加入到session缓存中,这个对象的引用就加入到了java的集合中,以后即使应用程序中的引用变量不再引用该对象,只要session缓存不被清空,这个对象一直处于生命周期中。
session缓存的作用:
1)减少访问数据库的频率。
2)保证缓存中的对象与数据库中的相关记录保持同步。
session清理缓存的时机:
1)当调用transaction的commit()方法时,commit()方法先清理缓存(前提是flushmode.commit/auto),然后再向数据库提交事务。
2)当应用程序调用session的find()或者iterate()时,如果缓存中的持久化对象的属性发生了变化,就会先清理缓存,以保证查询结果能反映持久化对象的最新状态。
3)当应用程序显示调用session的flush()方法的时候。
session清理模式执行清理缓存操作的时间点:
session接口
session接口是hibernate向应用程序提供的操纵数据库的最主要的接口,它提供了基本的保存,更新,删除和查询的方法。
1.save():把一个临时对象加入到缓存中,是它变成持久化对象
-->选用映射文件指定的主键生成器为持久化对象分配唯一的oid
-->计划一条insert语句,把参数对象当前的属性值组装到insert语句中,但是save()方法并不立即执行sqlinsert语句,只有当session清理缓存时候才会执行。
-->如果在save()方法之后,又修改了持久化对象的属性,会使得session在清理缓存的时候额外执行sqlupdate语句。
注意:save()方法是用来持久化一个临时对象的!
如果将一个持久化对象传给save()方法将不会执行任何操作,多余的步骤
如果将一个游离态对象传给save()方法,session会将它当作临时对象来处理,再次向数据库中插入一条记录,不符合业务需求!
2.update():把customer对象重新加入到session缓存中,使之变为持久化对象。
--->计划一条update语句,只有在清理缓存的时候才会执行,并且在执行的时候才会把参数对象中的属性值组装到update语句中。
注意:update()是将一个游离对象转变为持久化对象的。
只要通过update()方法使游离对象被一个session关联,即使没有修改参数对象的任何属性,session在清理缓存的时候也会执行由update方法计划的update语句。
3.saveorupdate():同时包含了save()与update()方法的功能,如果传入的参数是临时对象,调用save方法,如果参入参数是游离对象,调用update()方法,如果传入的是持久化对象,直接返回。
4.load()/get():都会根据给定的oid从数据库中加载一个持久化对象,区别在于,当数据库中不存在与oid对应的记录时,load()方法会抛出objectnotfoundexception异常,而get()方法返回null.
5.delete():用于从数据库中删除与参数对象对应的记录,如果传入的参数是持久化对象,session就计划执行一个delete语句,如果传入的参数是游离对象,先使游离对象被session关联,使它变为持久化对象,然后计划一个delete语句,在清理缓存的时候执行。
6.evict():从缓存中清除参数指定的持久化对象。
适用场合:不希望session继续按照该对象的状态改变来同步更新数据库。
在批量更新或批量删除的场合,当更新或者删除一个对象后,及时释放该对象占用的内存。当然批量操作优先考虑jdbc.
7.clear():清空缓存中所有持久化对象。
总结
以上就是快速了解hibernate中的session的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题。如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!