所谓懒加载就是两个对象关联查询时,不立即查询出来关联的对象,而是用到的时候再去查询。比如我们查用户信息不需要查账户信息,这个时候就用到了懒加载。
1、需要在全局配置文件中开启懒加载机制
<settings>
<!--开启Mybatis支持延迟加载-->
<setting name="lazyLoadingEnabled" value="true"/>
<setting name="aggressiveLazyLoading" value="false"></setting>
</settings>
2、
查询账户时不立刻查询用户
IAccountDao.xml
<!-- 定义封装account和user的resultMap -->
<resultMap id="accountUserMap" type="account">
<id property="id" column="id"></id>
<result property="uid" column="uid"></result>
<result property="money" column="money"></result>
<!-- 一对一的关系映射:配置封装user的内容
select属性指定的内容:查询用户的唯一标识:
column属性指定的内容:用户根据id查询时,所需要的参数的值
-->
<association property="user" column="uid" javaType="user" select="com.itheima.dao.IUserDao.findById"></association>
</resultMap>
<!-- 查询所有 -->
<select id="findAll" resultMap="accountUserMap">
select * from account
</select>
IAccountDao.java
List<Account> findAll();
IUserDao.java
User findById(Integer userId);
IUserDao.xml
<!-- 根据id查询用户 -->
<select id="findById" parameterType="INT" resultType="user">
select * from user where id = #{uid}
</select>
3、查询用户时不立即查询账户
IUserDao.xml
<!-- 定义User的resultMap-->
<resultMap id="userAccountMap" type="user">
<id property="id" column="id"></id>
<result property="username" column="username"></result>
<result property="address" column="address"></result>
<result property="sex" column="sex"></result>
<result property="birthday" column="birthday"></result>
<!-- 配置user对象中accounts集合的映射 -->
<collection property="accounts" ofType="account" select="com.itheima.dao.IAccountDao.findAccountByUid" column="id"></collection>
</resultMap>
<!-- 查询所有 -->
<select id="findAll" resultMap="userAccountMap">
select * from user
</select>
IUserDao.java
List<User> findAll();
IAccountDao.java
List<Account> findAccountByUid(Integer uid);
IAccountDao.xml
<!-- 根据用户id查询账户列表 -->
<select id="findAccountByUid" resultType="account">
select * from account where uid = #{uid}
</select>
这样就实现了懒加载,就是在association和collection中配置select标签,该标签去查询另外一个关联对象的属性。在实际应用中一对一最好立刻加载,而一对多则可以开启懒加载,具体也要看实际情况而定。