Mybatis的懒加载(延迟加载)机制。
懒加载:按需加载,即当使用时候再去查询而不是,未在使用时就发送sql查询出来数据。
作用:降低数据库压力。
用于一对一查询,一对多查询时。
使用:使用resultMap映射数据库类型。使用association、collection实现一对一及一对多映射)。
其实:懒加载就是按需执行,也可以不做此配置。
例如:查询用户并查询出该用户的所有订单,可以使用业务限制。
查询出所有用户后,获取用户信息,user.getOrderId(),作为查询Order的id。
配置:
- sqlMapConfig.xml 设置setting配置开启二级缓存。
<settings>
<!--延迟加载总开关 -->
<setting name="lazyLoadingEnabled" value="true" />
<!--侵入式延迟加载开关 -->
<!--3.4.1版本之前默认是true,之后默认是false -->
<setting name="aggressiveLazyLoading" value="true" />
</settings>
- 解决cglib动态代理报错 Cannot enable lazy loading because CGLIB is not available. Add CGLIB to your...配置pom.xml中
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>3.2.5</version>
</dependency>
3、编写xxxMapper.xml文件。
测试文件: