首页 > 学院 > 操作系统 > 正文

hibernate的查询的比较

2024-06-28 16:01:54
字体:
来源:转载
供稿:网友
hibernate的查询有很多,Query,find,Criteria,get,loadquery使用hsql语句,可以设置参数是常用的一种方式criteria的方式,尽量避免了写hql语句,看起来更面向对象了。find方式,这种方式已经被新的hibernate丢弃get和load方式是根据id取得一个记录下边详细说一下get和load的不同,因为有些时候为了对比也会把find加进来。1,从返回结果上对比:load方式检索不到的话会抛出org.hibernate.ObjectNotFoundException异常get方法检索不到的话会返回null2,从检索执行机制上对比:get方法和find方法都是直接从数据库中检索而load方法的执行则比较复杂1,首先查找session的persistent Context中是否有缓存,如果有则直接返回2,如果没有则判断是否是lazy,如果不是直接访问数据库检索,查到记录返回,查不到抛出异常3,如果是lazy则需要建立代理对象,对象的initialized属性为false,target属性为null4, 在访问获得的代理对象的属性时,检索数据库,如果找到记录则把该记录的对象复制到代理对象的target

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

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


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表