mybatis的延迟加载

来源:互联网 发布:淘宝店铺一颗心 编辑:程序博客网 时间:2024/05/16 10:39

需要查询关联信息时,使用mybatis延迟加载特性可有效的减少数据库压力,首次查询只查询主要信息,关联信息等用户获取时再加载。

 

1  打开延迟加载开关

在mybatis核心配置文件中配置:

lazyLoadingEnabled、aggressiveLazyLoading

设置项

描述

允许值

默认值

lazyLoadingEnabled

全局性设置懒加载。如果设为‘false’,则所有相关联的都会被初始化加载。

true | false

false

aggressiveLazyLoading

当设置为‘true’的时候,懒加载的对象可能被任何懒属性全部加载。否则,每个属性都按需加载。

true | false

true

 

 

<settings>

       <setting name="lazyLoadingEnabled"value="true"/>

       <setting name="aggressiveLazyLoading"value="false"/>

</settings>

 

 

2  一对一查询延迟加载

2.1 需求

查询订单信息,关联查询用户信息。

默认只查询订单信息,当需要查询用户信息时再去查询用户信息。

 

2.2 Sql语句:

 

SELECT

 orders.*

FROM

 orders

 

2.3 定义po类

在Orders类中加入User属性。

 

 

2.4 Mapper.xml

<selectid="findOrdersList3"resultMap="userordermap2">

    SELECT

    orders.*

    FROM

    orders

</select>

 

2.5 定义resultMap

<!--订单信息resultmap -->

<resultMaptype="com.hsl.mybatis.pojo.Orders" id="userordermap2">

<idproperty="id"column="id"/>

<resultproperty="user_id" column="user_id"/>

<resultproperty="number" column="number"/>

<associationproperty="user" javaType="com.hsl.mybatis.pojo.User"  select="findUserById"  column="user_id"/>

</resultMap>

 

association

select="findUserById":指定关联查询sql为findUserById

column="user_id":关联查询时将users_id列的值传入findUserById

最后将关联查询结果映射至com.hsl.mybatis.pojo.User

 

 

2.6 Mapper接口:

public List<Orders> findOrdersList3()  throws Exception;

 

2.7 测试:

 

Public void testfindOrdersList3() throws Exception{

       //获取session

       SqlSession session = sqlSessionFactory.openSession();

       //获限mapper接口实例

       UserMapper userMapper = session.getMapper(UserMapper.class);

       //查询订单信息

       List<Orders> list = userMapper.findOrdersList3();

       System.out.println(list);

       //开始加载,通过orders.getUser方法进行加载

for(Orders orders:list){

           System.out.println(orders.getUser());

       }

       //关闭session

       session.close();

    }

 

2.8 延迟加载的思考

不使用mybatis提供的延迟加载功能是否可以实现延迟加载?

 

实现方法:

针对订单和用户两个表定义两个mapper方法。

1、订单查询mapper方法

2、根据用户id查询用户信息mapper方法

默认使用订单查询mapper方法只查询订单信息。

当需要关联查询用户信息时再调用根据用户id查询用户信息mapper方法查询用户信息。

 

3  一对多延迟加载

一对多延迟加载的方法同一对一延迟加载,在collection标签中配置select内容。

 

4  延迟加载小结

作用:

         当需要查询关联信息时再去数据库查询,默认不去关联查询,提高数据库性能。

         只有使用resultMap支持延迟加载设置。

场合:

         当只有部分记录需要关联查询其它信息时,此时可按需延迟加载,需要关联查询时再向数据库发出sql,以提高数据库性能。

         当全部需要关联查询信息时,此时不用延迟加载,直接将关联查询信息全部返回即可,可使用resultType或resultMap完成映射。
0 0
原创粉丝点击