终结篇 MyBatis 解析 (四)-- Sql 执行过程

本文详细介绍了MyBatis框架内部的SQL执行流程,包括如何通过DefaultSqlSession找到MappedStatement对象,生成可执行的SQL语句,设置参数,执行查询并生成结果集的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SqlSession有一个默认的实现DefaultSqlSession, 在DefaultSqlSession中有一个Executor对象,对象数据的操作都是由这个Executor来完成。Executor中有三个对象来帮助他完成MappedStatement的执行工作。

StatementHandler负责从连接中获取一个Statement对象
ParameterHandler负责对Statement设置参数
ResultHandler负责生成查询语句的结果集

重点介绍两个属性:

protected final Map<String, MappedStatement> mappedStatements = new StrictMap<MappedStatement>("Mapped Statements collection");  
protected final Map<String, ResultMap> resultMaps = new StrictMap<ResultMap>("Result Maps collection");  

mappedStatements属性,保存了所有Mapper配置文件中的select/update/insert/delete节点信息。属性类型为一个Map,key为sql对应的ID,MappedSatement为一个java对象,保存了一个select/update/insert/delete的节点信息。

resultMaps属性,保存了所有Mapper配置文件中的resultMap节点,Mapper配置文件也主要是配置select/update/insert/delete/resultMap这几个节点。

SQL执行过程:

  1. DefaultSqlSession根据id在configuration中找到MappedStatement对象(要执行的语句)
  2. Executor调用MappedStatement对象的getBoundSql得到可执行的sql和参数列表
  3. StatementHandler根据Sql生成一个Statement
  4. ParameterHandler为Statement设置相应的参数
  5. Executor中执行sql语句
  6. 如果是更新(update/insert/delete)语句,sql的执行工作得此结束
  7. 如果是查询语句,ResultSetHandler再根据执行结果生成ResultMap相应的对象返回。

具体详情如下图:
这里写图片描述

也可以参照结构图, 便于理解.
这里写图片描述

其他:
sql执行时, 几个主要对象调用关系可以参考下图:

这里写图片描述
调用堆栈

org.apache.ibatis.executor.BaseExecutor#queryFromDatabase
	org.apache.ibatis.executor.SimpleExecutor#doQuery
		org.apache.ibatis.session.Configuration#newStatementHandler
			java.sql.PreparedStatement#execute

参照: https://blog.youkuaiyun.com/ashan_li/article/details/50425901

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值