MyBatis的懒加载(延迟加载)

什么是懒加载

所谓懒加载就是按需加载。

例如:

MyBatis的懒加载(延迟加载)_第1张图片

对象模型就是一个订单中持有一个对用户的引用。

当查询订单信息时,暂时不加载用户信息。就延迟加载(懒加载)。

 

什么情况下才能使用懒加载呢?

MyBatis的懒加载(延迟加载)_第2张图片

上面的情况是无法实现懒加载的。因为是连接查询,所以在查询时只是执行了一次sql语句,就查询所有的数据.

MyBatis的懒加载(延迟加载)_第3张图片

这种情况可能出现延迟加载,第一次查询结束之后,不在执行第二次查询。

如何配置

查看文档:

MyBatis的懒加载(延迟加载)_第4张图片

MyBatis的懒加载(延迟加载)_第5张图片

配置这两个属性:

MyBatis的懒加载(延迟加载)_第6张图片

测试

@Test

    public void testQueryOrderUserResultMap() {

       // 通过factory得到sqlsession

       SqlSession sqlSession = factory.openSession();

       // 通过sqlSession得到一个mapper对象。(动态代理)

       OrderMapper mapper = sqlSession.getMapper(OrderMapper.class);

       //查询

       List orders = mapper.queryOrderUserResultMap();

       for (Order order : orders) {

           System.out.println("订单编号:"+order.getNumber());

       }

    }

效果:

MyBatis的懒加载(延迟加载)_第7张图片

当不使用user对象时,不会执行查询用户的sql。

 

当然也可以通过局部设置属性覆盖全局的设置:

 

你可能感兴趣的:(java)