MyBatis延迟加载
什么是延迟加载?
前面我们讲解Mybatis中的一对一,一对多,多对多关系的配置及实现,可以实现对象的关联查询。在实际使用中的大多数时间里查询用户信息时是不需要查询它的账户信息的。此时就可以使用延迟加载策略。就是在需要用到数据时才进行加载,不需要用到数据时就不加载数据。延迟加载也称懒加载。
使用association实现的延迟加载
这里我们使用前面讲到的账户和用户的一对一关系,修改AccountDao.xml
映射文件如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.zfnotes.dao.AccountDao">
<!--定义封装Account和User的resultMap-->
<resultMap id="auMap" type="account">
<id column="aid" property="id"/>
<result property="uid" column="uid"/>
<result property="money" column="money"/>
<!--一对一的关系映射,封装user的内容-->
<association property="user"
select="com.zfnotes.dao.UserDao.findById"
colu