getHibernateTemplate().find(hql); getHibernateTemplate().load的区别

getHibernateTemplate().find(hql); getHibernateTemplate().load的区别,第1张

get和load方式是根据id取得一个记录

下边详细说一下get和load的不同,因为有些时候为了对比也会把find加进来。

1从返回结果上对比:

load方式检索不到的话会抛出orghibernateObjectNotFoundException异常

get方法检索不到的话会返回null

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

3根本区别说明

如果你使用load方法,hibernate认为该id对应的对象(数据库记录)在数据库中是一定存在的,所以它可以放心的使用,它可以放心的使用代理来 延迟加载该对象。在用到对象中的其他属性数据时才查询数据库,但是万一数据库中不存在该记录,那没办法,只能抛异常。所说的load方法抛异常是指在使用 该对象的数据时,数据库中不存在该数据时抛异常,而不是在创建这个对象时(注意:这就是由于“延迟加载”在作怪)。

由于session中的缓存对于hibernate来说是个相当廉价的资源,所以在load时会先查一下session缓存看看该id对应的对象是否存在,不存在则创建代理。所以如果你知道该id在数据库中一定有对应记录存在就可以使用load方法来实现延迟加载。

对于get方法,hibernate会确认一下该id对应的数据是否存在,首先在session缓存中查找,然后在二级缓存中查找,还没有就查数据库,数据库中没有就返回null。

对于load和get方法返回类型:虽然好多书中都这么说:“get()永远只返回实体类”,但实际上这是不正确的,get方法如果在 session缓存中找到了该id对应的对象,如果刚好该对象前面是被代理过的,如被load方法使用过,或者被其他关联对象延迟加载过,那么返回的还是 原先的代理对象,而不是实体类对象,如果该代理对象还没有加载实体数据(就是id以外的其他属性数据),那么它会查询二级缓存或者数据库来加载数据,但是 返回的还是代理对象,只不过已经加载了实体数据。

get方法首先查询session缓存,没有的话查询二级缓存,最后查询数据库;反而load方法创建时首先查询session缓存,没有就创建代理,实际使用数据时才查询二级缓存和数据库。

4简单总结

总之对于get和load的根本区别,一句话,hibernate对于load方法认为该数据在数据库中一定存在,可以放心的使用代理来延迟加载,如果在使用过程中发现了问题,只能抛异常;而对于get方法,hibernate一定要获取到真实的数据,否则返回null。

在实际开发中可能会遇到需要获取对象的所有属性,这时你可能会自己来遍历一遍获取,其实原生js已经为我们提供了一个方法,他就是Objectkeys(),它返回一个数组,就可以结合forEach方法遍历对象。

1对象

// 1对象

var a = {

a : 123,

b : 'asd',

c : function() {

consolelog( 'haha' );

}

};

consolelog( Objectkeys( a ) ); // [ 'a', 'b', 'c' ]

2数组

// 2数组

var b = [ 123, 21, 31 ];

consolelog( Objectkeys( b ) ); // [ '0', '1', '2' ]

3构造函数

// 3构造函数

function c() {

thisaa = 123;

thisbb = 'asdas';

thiscc = function() {

}

consolelog( Objectkeys( c ) ); // []

4实例化对象

// 4实例化对象

var d = new c();

consolelog( Objectkeys( d ) ); // [ 'aa', 'bb', 'cc' ]

5字符串

// 5字符串

var e = 'sdf123';

consolelog( Objectkeys( e ) ); // [ '0', '1', '2', '3', '4', '5' ]

1、查看自己写的语句,没有丝毫的错误。放到SQL查询分析器执行。也能检索出数据。

这确保了这条语句是没错的。

提示:Hibernate中的SQL语句是不区分大小写的,即便是你查询的表名。比如你写成这

样也是合法的

"SEleCt

fRoM

ClaSSes

"。那么Hibernate怎样 *** 作对象?问题的关键

是这里sQueryaddEntity(Classesclass);这条语句,

你要正确填写你要检索的表的

实体,它必须是你存在的POJO。

2、使用Hibernate官方推荐的HQL查询,同样的数据库,同样的表。结果是正确的。这

确保了数据库链接是绝对没有问题的。

3、仔细检查我写的SQL查询方法,没有发现什么语法错误。

4、检查我查询表的POJO对象的映射文件XXXhbmxml

,主键生成方式是

native

。似

乎也没有错误。

5、检查数据库检索表的主键,也已经设成自动增长。

以上就是关于getHibernateTemplate().find(hql); getHibernateTemplate().load的区别全部的内容,包括:getHibernateTemplate().find(hql); getHibernateTemplate().load的区别、Object.keys()来获取对象的属性、hibernate查询数据库时采用sql查询得出的结果没有对象名称,该怎么解决呢等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/web/9545170.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-29
下一篇 2023-04-29

发表评论

登录后才能评论

评论列表(0条)

保存