Mybatis执行sql流程(一)

文章目录

代码中的两行代码是如何执行的?

java 复制代码
UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
userMapper.selectById(userId);

第一行:

获取 Mapper 接口的代理对象,调用链如下:

java 复制代码
SqlSession.getMapper() 
	→ Configuration.getMapper() 
		→ MapperRegistry.getMapper() // 使用map做了缓存,若没有则继续向下
			→ MapperProxyFactory.newInstance() // 使用 JDK 动态代理生成 Mapper 接口的代理对象。即返回的是一个动态生成代理类对象。具体的代理过程此处不详细介绍,在后文。

第二行:

执行SQL:动态代理拦截方法调用。
userMapper.selectById(userId); 上述得知userMapper对象是代理类对象,此处调用的selectById方法就是代理类中实现的接口方法(当然不是具体的实现内容,具体的实现内容在InvocationHandler与JDK动态代理相关)参考JDK动态代理

java 复制代码
// 例如:执行userMapper.selectUserById(1);
MapperProxy.invoke() // MapperProxy 就是InvocationHandler的实现,即具体实现内容在此。在调用链中还涉及到二级缓存的事情,后续说明
	→ MapperMethod.execute() // MapperMethod 将方法调用转为SqlSession的操作,如selectOne/insert等
		→ SqlSession.selectOne() 
			→ Executor.query() // 有多种执行器,后续详细说明
    			→ MappedStatement.getBoundSql() 
    			→ query() // 此处涉及到一级缓存的事情,后续说明;如果没有命中一级缓存,则查询数据库
    				→ Executor.prepareStatement() // 此处涉及到TypeHandler,将对应的java数据转化为sql类型的数据
    				→ StatementHandler.query()
    					→ PreparedStatement.execute() // 执行sql
    					→ ResultHandler.handleResultSets() // 此处涉及到TypeHandler,将结果集转化为java类型的数据

Client SqlSession MapperProxy MapperMethod Executor JDBC getMapper(UserMapper.class) 创建动态代理 userMapper.selectUserById(1) 解析方法调用 selectOne("selectUserById", 1) query() 执行 SQL 返回 ResultSet 转换为 User 对象 返回结果 Client SqlSession MapperProxy MapperMethod Executor JDBC

相关内容:
JDK代理

Mybatis加载Mapper

MapperRegistry

MyBatis中JDK动态代理

Mybatis之MapperProxy

Mybatis之MapperMethod

Mybatis之Executor执行器

Mybatis之StatementHandler

Mybatis之KeyGenerator

相关推荐
练习时长一年3 分钟前
AopAutoConfiguration源码阅读
java·spring boot·intellij-idea
源码宝1 小时前
【智慧工地源码】智慧工地云平台系统,涵盖安全、质量、环境、人员和设备五大管理模块,实现实时监控、智能预警和数据分析。
java·大数据·spring cloud·数据分析·源码·智慧工地·云平台
David爱编程2 小时前
面试必问!线程生命周期与状态转换详解
java·后端
LKAI.3 小时前
传统方式部署(RuoYi-Cloud)微服务
java·linux·前端·后端·微服务·node.js·ruoyi
2301_793086873 小时前
SpringCloud 07 微服务网关
java·spring cloud·微服务
柳贯一(逆流河版)4 小时前
Spring 三级缓存:破解循环依赖的底层密码
java·spring·缓存·bean的循环依赖
该用户已不存在5 小时前
OpenJDK、Temurin、GraalVM...到底该装哪个?
java·后端
TT哇6 小时前
@[TOC](计算机是如何⼯作的) JavaEE==网站开发
java·redis·java-ee
Tina学编程6 小时前
48Days-Day19 | ISBN号,kotori和迷宫,矩阵最长递增路径
java·算法