关于Hibernate的延迟加载

 

 为什么多对一的关系在hbm.xml文件中必须把class标签的lazy属性值必须设置成false才可以,还有返回查询返回List对象结果集时必须将hbm.xml文件的hibernate-mapping的属性default-lazy值设置成false否则就会出现下面的错误啊

 

 

08:42:43,546 ERROR LazyInitializationException:19 - could not initialize proxy - the owning Session was closed
org.hibernate.LazyInitializationException: could not initialize proxy - the owning Session was closed
at org.hibernate.proxy.AbstractLazyInitializer.initialize(AbstractLazyInitializer.java:60)
at org.hibernate.proxy.AbstractLazyInitializer.getImplementation(AbstractLazyInitializer.java:111)
at org.hibernate.proxy.pojo.cglib.CGLIBLazyInitializer.invoke(CGLIBLazyInitializer.java:172)

恩,是的.那个整合了spring.如果没整合spring的话你可以自己写一个过滤器,用来决定什么时候才关闭session.

还有,用了lazy=false会降低hibernate的数据检索效率.推荐使用fetch="join",然后在HQL语句中使用left join fetch的方式进行加载关联表的数据.

[color=red]如果需要用到的一对读的数据集合,那么就将lazy设置为false,如果不需要的话,想在需要用到的时候再去查找的话,那么设置lazy为true;[/color]

关于lazy机制:

延迟初始化错误是运用Hibernate开发项目时最常见的错误。如果对一个类或者集合配置了延迟检索策略,那么必须当代理类实例或代理集合处于持久化状态(即处于Session范围内)时,才能初始化它。如果在游离状态时才初始化它,就会产生延迟初始化错误。

lazy默认是true,就是当查询对象表时,不返回对象,而且返回对象的代理,当你出现session.close(),又去调用对象里面的属性,就会报以上错误

数据量大时,会造成加载速度慢,你可以在数据库表中建索引,你的问题具体也不知道

在web.xml中配置一个:

<filter>
    <filter-name>hibernateFilter</filter-name>
    <filter-class>org.springframework.orm.hibernate3.support.OpenSessionInViewFilter</filter-class>
    <init-param>
        <param-name>sessionFactoryBeanName</param-name>
        <param-value>sessionFactory</param-value>
    </init-param>
</filter>

<filter-mapping>
    <filter-name>hibernateFilter</filter-name>
    <url-pattern>/*</url-pattern>
</filter-mapping>