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

相关推荐
TanYYF几秒前
Spring Boot 异步处理框架核心源码解析及实现原理
java·spring boot·spring
百锦再9 分钟前
从 .NET 到 Java 的转型指南:详细学习路线与实践建议
android·java·前端·数据库·学习·.net·数据库架构
z晨晨12 分钟前
互联网大厂Java求职面试场景
java·redis·spring·面试·多线程·互联网大厂
方圆想当图灵30 分钟前
深入浅出 gRPC
java·后端·github
卷Java33 分钟前
uni-app 模板语法修复说明
java·数据库·spring boot·uni-app·mybatis
渣哥35 分钟前
新手最容易忽略!Spring 自动装配的 5 种方式全解析
java
库库83942 分钟前
Java微服务知识点详细总结
java·开发语言·微服务
没有bug.的程序员1 小时前
MySQL 在金融系统中的应用:强一致性与高可用架构实战
java·mysql·金融·架构·高可用·强一致性
sibylyue1 小时前
IDEA AI Agent
java·ide·intellij-idea
芒途之士2 小时前
okHttp 解决文件上传中文名错误 Unexpected char
java