关于hibernate的LazyInitializationException异常

关于hibernate的LazyInitializationException异常
hibernate3在one-to-many关联中,所有的实体设置文件中的lazy属性都被默认设成了lazy=“proxy”,此处proxy相当于true,lazy=”true“意思是延时加载,简单理解就是, 你使用了lazy=true,这样hibernate在从数据库中调数据的时候是不会把关联的对象查出来的,而是保存一个获取值得方法,在你使用getXXX()调用的时候,hiberante


会利用这个保存的方法去从数据库中取数据。


产生LazyInitializationException异常时因为在关闭了session后又试图使用session获取数据
可能产生该异常的原因:
1、 在one-to-many关联中,使用hibernate时,没有将lazy属性设置为false
※如果使用hibernate2,是没有lazy属性的,可以通过设置outer-join 设置为false来解决。
2、使用load方法时,不恰当的代码使得在操作为完成之前关闭了session 




hibernate中get和load两个方法的区别:
首先,对于Hibernate get方法,Hibernate会确认一下该id对应的数据是否存在,首先在session缓存中查找,
然后在二级缓存中查找,还没有就查询数据库,数据库中没有就返回null。
其次,对于load方法,Hibernate load方法加载实体对象的时候,根据映射文件上类级别的lazy属性的配置(默认为true),
区分对待:
1、若为true,则首先在Session缓存中查找,看看该id对应的对象是否存在,不存在则使用延迟加载,
返回实体的代理类对象(该代理类为实体类的子类,由cglib动态生成)。
等到具体使用该对象(除获取OID以外)的时候,再查询二级缓存和数据库,
若仍没发现符合条件的记录,则会抛出一个ObjectNotFoundException
2、若为false,就跟Hibernate get方法查找顺序一样,只是最终若没发现符合条件的记录,
则会抛出一个ObjectNotFoundException


get和load有两个重要区别:  如果未能发现符合条件的记录,Hibernate get方法返回null,而load方法会抛出一个ObjectNotFoundException
load 方法可返回没有加载实体数据的代理类实例,而get方法永远返回有实体数据的对象。


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



你可能感兴趣的:(问题解决)