懒加载异常的解决

<filter>  
        <!-- 
               平时使用懒加载时,有可能会因为hibernate的session(或着jpa的EntityManager)在事务结束时的关闭,导致页面调用数据时,出现懒加载异常 
               可以这样配置解决懒加载异常,让session在页面上也能使用,
               但会使session打开的时间稍微长一点,并发量大时会使性能有所下降,但一般的项目没问题
               
        -->
        <filter-name>OpenSessionInViewFilter</filter-name> 
        <!-- 
            jpa
         -->
         <filter-class>org.springframework.orm.jpa.support.OpenEntityManagerInViewFilter</filter-class>  
        <!-- 
            hibernate4
        <filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class>  
         -->
    </filter>

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

 

转载于:https://www.cnblogs.com/wwzyy/p/5926476.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis懒加载是指在查询关联对象时,只有在真正使用到这些对象时才会进行加载,而不是在查询主对象时就一次性加载所有关联对象。这样可以减少不必要的数据库查询,提高查询效率。 在MyBatis中,可以通过配置来实现懒加载。一种常用的方式是使用MyBatis的association和collection标签来配置关联对象的懒加载。association用于一对一关系的懒加载,而collection用于一对多关系的懒加载。 例如,假设有一个User对象关联一个Order对象列表,可以通过如下配置来实现懒加载: ```xml <resultMap id="userResultMap" type="User"> <id property="id" column="id" /> <result property="name" column="name" /> <collection property="orders" ofType="Order" select="selectOrdersByUserId" fetchType="lazy" /> </resultMap> ``` 上述配置中,fetchType="lazy"表示orders列表的加载方式为懒加载。当查询User对象时,只有在访问orders列表时才会执行selectOrdersByUserId查询语句,实现懒加载。 需要注意的是,懒加载需要确保在Session关闭之前访问关联对象,否则会抛出异常。可以使用Session的selectList方法来解决该问题,如: ```java List<User> users = session.selectList("selectUsers"); for (User user : users) { List<Order> orders = user.getOrders(); // 访问关联对象,触发懒加载 // ... } ``` 通过配置和正确使用Session,可以实现MyBatis的懒加载功能,提高查询性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值