hibernate的查询的比较

来源:互联网 发布:国税局王军垃圾知乎 编辑:程序博客网 时间:2024/06/10 02:44
hibernate的查询有很多,Query,find,Criteria,get,load


query使用hsql语句,可以设置参数是常用的一种方式


criteria的方式,尽量避免了写hql语句,看起来更面向对象了。


find方式,这种方式已经被新的hibernate丢弃


get和load方式是根据id取得一个记录
下边详细说一下get和load的不同,因为有些时候为了对比也会把find加进来。


1,从返回结果上对比:
load方式检索不到的话会抛出org.hibernate.ObjectNotFoundException异常
get方法检索不到的话会返回null


2,从检索执行机制上对比:
get方法和find方法都是直接从数据库中检索
而load方法的执行则比较复杂
1,首先查找session的persistent Context中是否有缓存,如果有则直接返回
2,如果没有则判断是否是lazy,如果不是直接访问数据库检索,查到记录返回,查不到抛出异常
3,如果是lazy则需要建立代理对象,对象的initialized属性为false,target属性为null
4, 在访问获得的代理对象的属性时,检索数据库,如果找到记录则把该记录的对象复制到代理对象的target

上,并将initialized=true,如果找不到就抛出异常 。


注:No row with the given identifier exists(数据问题,两张表中外键关联的数据不一致)

0 0
原创粉丝点击