MyBatis框架——延迟加载
延迟加载也叫惰性加载或者懒加载,使⽤延迟是为了提⾼程序的运⾏效率,具体是通过尽量少执⾏ SQL 语句来提升效率。Java 程序与数据库的交互频率越低越好,MyBatis 提供的延迟加载功能就可以做到这 ⼀点。
延迟加载是作⽤于级联查询的场景下:
查询⽬标表时,如果仅查询⽬标表就可以获取相应的字段,则不需要查询级联表;
除⾮必须查询级联表才能获取的字段,则查询级联表,通过延迟加载可以有效减少 SQL 语句的执⾏次数。
延迟加载的思路:
将级联查询的 SQL 语句进⾏拆分,不要⽤⼀条 SQL 语句进⾏级联查询,改为两条 SQL 的单表查询。
当我们查询 Order 的时候,如果没有访问 customer 的属性,则只发送⼀条 SQL 语句查询 Order;
如果需要访问 customer 的属性,则发送两条 SQL 语句查询 Order 和 Customer。
示例:
1、创建数据库
2、创建实体类
package com.sunjian.entity; import java.util.List; /** * @author sunjian * @date 2020/3/23 14:37 */ public class Customer { private Long id; private String name; private List<Order> orders; public List<Order> getOrders() { return orders; } public void setOrders(List<Order> orders) { this.orders = orders; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "Customer{" + "id=" + id + ", name='" + name + '\'' + ", orders=" + orders + '}'; } }
package com.sunjian.entity; /** * @author sunjian * @date 2020/3/23 14:38 */ public class Order { public Long getId() { return id; } @Override public String toString() { return "Order{" + "id=" + id + ", name='" + name + '\'' + ", customer=" + customer + '}'; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Customer getCustomer() { return customer; } public void setCustomer(Customer customer) { this.customer = customer; } private Long id; private String name; private Customer customer; }
3、创建repository接口
package com.sunjian.repository; import com.sunjian.entity.Customer; import com.sunjian.entity.Order; /** * @author sunjian * @date 2020/3/23 14:41 */ public interface CustomerRepository { public Customer findCustomerById(Long id); }
package com.sunjian.repository; import com.sunjian.entity.Order; /** * @author sunjian * @date 2020/3/23 14:41 */ public interface OrderRepository { public Order findOrderById(Long id); }
4、创建repository.xml编写SQL(单独查询)
<?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.sunjian.repository.CustomerRepository"> <select id="findCustomerById" parameterType="java.lang.Long" resultType="com.sunjian.entity.Customer"> select * from t_customer where id = #{id} </select> </mapper>
<?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.sunjian.repository.OrderRepository"> <resultMap id="orderMap" type="com.sunjian.entity.Order"> <id property="id" column="id"></id> <result property="name" column="name"></result> <!-- 将查询结果中的cid字段,映射为另一个接口中的参数;达到级联查询--> <association property="customer" javaType="com.sunjian.entity.Customer" column="cid" select="com.sunjian.repository.CustomerRepository.findCustomerById"></association> </resultMap> <select id="findOrderById" parameterType="java.lang.Long" resultMap="orderMap"> select * from t_order where id = #{id} </select> </mapper>
5、创建config.xml全局配置文件(开启延迟加载配置),将repository.xml注册到config.xml中
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <!-- 打印SQL语句 --> <settings> <setting name="logImpl" value="STDOUT_LOGGING"/> <!-- 开启延迟加载 --> <setting name="lazyLoadingEnabled" value="true"/> </settings> <!-- 配置 MyBatis 数据源 --> <environments default="development"> <environment id="development"> <!-- JDBC事务管理 --> <transactionManager type="JDBC"></transactionManager> <dataSource type="POOLED"> <property name="driver" value="com.mysql.cj.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mybatis?serverTimezone=UTC"/> <property name="username" value="root"/> <property name="password" value="root"/> </dataSource> </environment> </environments> <!-- 注册 --> <mappers> <!-- 单表 --> <mapper resource="com/sunjian/mapper/UserMapper.xml"></mapper> <mapper resource="com/sunjian/repository/UserRepository.xml"></mapper> <!-- 多表 一对一 --> <mapper resource="com/sunjian/repository/StudentRepository.xml"></mapper> <!-- 多表 一对多 --> <mapper resource="com/sunjian/repository/ClassesRepository.xml"></mapper> <!-- 多表 多对多 --> <mapper resource="com/sunjian/repository/CourseRepository.xml"></mapper> <mapper resource="com/sunjian/repository/OrderRepository.xml"></mapper> <mapper resource="com/sunjian/repository/CustomerRepository.xml"></mapper> </mappers> </configuration>
6、创建测试类
package com.sunjian.test; import com.sunjian.entity.Customer; import com.sunjian.entity.Order; import com.sunjian.entity.User; import com.sunjian.repository.CustomerRepository; import com.sunjian.repository.OrderRepository; import com.sunjian.repository.UserRepository; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; import org.apache.ibatis.session.SqlSessionFactoryBuilder; import java.io.InputStream; /** * @author sunjian * @date 2020/3/22 10:20 */ public class Test { public static void main(String[] args) { // Mapper 代理实现自定义接口 InputStream inputStream = Order.class.getClassLoader().getResourceAsStream("config.xml"); SqlSessionFactoryBuilder sqlSessionFactoryBuilder = new SqlSessionFactoryBuilder(); SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBuilder.build(inputStream); SqlSession sqlSession = sqlSessionFactory.openSession(); // 获取接口的处理对象 OrderRepository orderRepository = sqlSession.getMapper(OrderRepository.class); Order order = orderRepository.findOrderById(1L); System.out.println(order.getName()); } }
开启延迟加载
Opening JDBC Connection Created connection 793315160. Setting autocommit to false on JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@2f490758] ==> Preparing: select * from t_order where id = ? ==> Parameters: 1(Long) <== Columns: id, name, cid <== Row: 1, 订单1, 1 <== Total: 1 订单1
未开启延迟加载
Opening JDBC Connection Created connection 793315160. Setting autocommit to false on JDBC Connection [com.mysql.cj.jdbc.ConnectionImpl@2f490758] ==> Preparing: select * from t_order where id = ? ==> Parameters: 1(Long) <== Columns: id, name, cid <== Row: 1, 订单1, 1 ====> Preparing: select * from t_customer where id = ? ====> Parameters: 1(Long) <==== Columns: id, name <==== Row: 1, 张三 <==== Total: 1 <== Total: 1 订单1
OK.
MyBatis框架——延迟加载的更多相关文章
- 在mybatis框架中,延迟加载与连表查询的差异
1.引子 mybatis的延迟加载,主要应用于一个实体类中有复杂数据类型的属性,包括一对一和一对多的关系(在xml中用collection.association标签标识).这个种属性往往还对应着另一 ...
- Hibernate框架与Mybatis框架的对比
学习了Hibernate和Mybatis,但是一直不太清楚他们两者的区别的联系,今天在网上翻了翻,就做了一下总结,希望对大家有帮助! 原文:http://blog.csdn.net/firejuly/ ...
- MyBatis 框架笔记
Mybatis 框架笔记 ------技术源于热爱! 获取更多内容请关注小编的个人微信公众平台 1 Mybatis入门 1.1 单独使用jdbc编程问题总结 1.1.1 jd ...
- 【mybatis】使用mybatis框架中踩过的坑
好久没来记录一下自己的学习情况,最近都在学框架,今天来记录一下关于mybatis框架的学习过程中碰过的一些问题: 以下内容可能稍微有点凌乱,因为是把之前遇到过的错误或异常都集中一起了,不过我已经把问题 ...
- mybatis的延迟加载、一级缓存、二级缓存
mybatis的延迟加载.一级缓存.二级缓存 mybatis是什么? mybatis是一个持久层框架,是apache下的开源项目,前身是itbatis,是一个不完全的ORM框架,mybatis提供输入 ...
- Spring MVC 学习总结(十)——Spring+Spring MVC+MyBatis框架集成(IntelliJ IDEA SSM集成)
与SSH(Struts/Spring/Hibernate/)一样,Spring+SpringMVC+MyBatis也有一个简称SSM,Spring实现业务对象管理,Spring MVC负责请求的转发和 ...
- MyBatis框架的使用及源码分析(九) Executor
从<MyBatis框架的使用及源码分析(八) MapperMethod>文中我们知道执行Mapper的每一个接口方法,最后调用的是MapperMethod.execute方法.而当执行Ma ...
- MyBatis框架的使用及源码分析(三) 配置篇 Configuration
从上文<MyBatis框架中Mapper映射配置的使用及原理解析(二) 配置篇 SqlSessionFactoryBuilder,XMLConfigBuilder> 我们知道XMLConf ...
- MyBatis 框架 基础应用
1.ORM的概念和优势 概念: 对象关系映射(Object Relational Mapping,简称ORM)是通过使用描述对象和数据库之间映射的元数据,将面向对象语言程序中的对象自动持久化到关系数据 ...
随机推荐
- MyBatis学习总结之一对多映射
1.首先创建2张表:students 和grades create table grades( gid ) primary key, gname varchar() ); create table s ...
- python 自动发送邮件遇到的问题
在学习自动化测试高级应用,根据内容写关于自动发送邮件出现了几个问题以及解决办法: 问题1: 代码写好之后,运行的时候,出现如下报错: SMTPAuthenticationError: (550, '\ ...
- python——实现三级菜单选择的功能(原创)
#coding:utf-8 dict={'beijing':{'haidingqu':['qinghe','keji'],'chaoyangqu':['q','w']},'shandong':{'li ...
- python pip配置以及安装工具包的一些方法
pip是python的一个工具包管理工具,可以下载安装需要的工具包,想要使用它来管理工具包首先要安装pip,安装方法可以参照下面这个网址来进行: https://www.cnblogs.com/Nan ...
- 谈谈Spring的IoC之注解扫描
问题 IoC是Inversion of Control的缩写,翻译过来即"控制反转".IoC可以说是Spring的灵魂,想要读懂Spring,必先读懂IoC.不过有时候硬着头皮 ...
- 阿里云服务器上搭建seafile专业版
因为官方一键安装教程在阿里云服务器上无法安装,由于水平有限,无法解决,所以选择手动安装 参考资料: 1,.腾讯云搭建seafile服务器 2.How to Install Seafile with N ...
- abp框架运行——前后端分离(基于VUE)
目录 1.介绍abp 2.abp如何工作 3.运行Domo 3.1官网点击 创建Demo 3.2 配置NetCore,选择Vue 3.3 输入系统名称验证码 4.官方手册文档 5.VUE项目 6. S ...
- Slog27_支配vue框架初阶项目之博客网站-样式居中
ArthurSlog SLog-27 Year·1 Guangzhou·China July 30th 2018 GitHub 掘金主页 简书主页 segmentfault 没有写够足够的代码量,想成 ...
- 前端ps中常用的操作
昨天,ui给了个psd图,让写成网页.额,要自己切图.很久之前,操作的还凑乎.但是,好久了,都忘了.所以,打算自己记个笔记,方便以后查看. 首先,打开ps就先来设置一下ps的单位啦点击最上面的一行的编 ...
- 37个JavaScript基本面试问题和解答
1.使用typeof bar ==="object"来确定bar是否是一个对象时有什么潜在的缺陷?这个陷阱如何避免? 尽管typeof bar ==="object&qu ...