MyBatis深入解读懒加载的实现

网友投稿 230 2022-10-09

MyBatis深入解读懒加载的实现

懒加载 ,也称为嵌套查询

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

Mybatis 一对一关联的 association 和一对多的 collection 可以实现懒加载。懒加载时要 使用resultMap,不能使用 resultType 。

这里我们以员工表和部门表为例

通过deptId 与 部门表 id 关联

 我们这里首先需要开启一个设置

懒加载功能是默认开启的, 但这里我们也需要设置这个属性, 不设置则不会触发延迟加载功能

Employee selectOneEmployee(int id);

我们以查询单个员工为例 , resultMap 与sql 如下

select="selectDept" column="deptId">

select="selectDept" column="deptId">

select id,name,age,deptId from employee where id=#{id}

select name from dept where LAKkWiuid=#{deptId}

此处一对一 ,我们使用

java测试 :

public static void main(String[] args) {

SqlSessiohttp://n sqlSession= MybatisUtil.getSqlSession();

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

Employee employee = mapper.selectOneEmployee(3);

System.out.println(employee);

System.out.println(employee.getDept());

sqlSession.commit(); //提交事务

sqlSession.close(); //关闭

查询结果 :

通过结果可以看到 , 当我们第一次输出这个 employee 对象时, 部门是没有被查询的 , 而当我们需要使用到部门的信息时, 才会去触发这个查询

查询部门 resultMap 与 sql如下:

select="selectEmployee" fetchType="lazy" column="id">

select="selectEmployee" fetchType="lazy" column="id">

SELECT id,name FROM dept where id=#{id}

select name from employee where deptId=#{id}

一对多,我们使用

懒加载就介绍到这里,感谢阅读

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:基于Serverless架构的盲盒抽奖系统(1500份礼品 自己部署自己抽)
下一篇:#yyds干货盘点# Prometheus Exporter(三) cAdvisor
相关文章

 发表评论

暂时没有评论,来抢沙发吧~