第六章 SqlSession 执行 Mapper 过程

在 MyBatis 3 中,SqlSession 执行 Mapper 的过程是一个涉及多个组件和步骤的复杂流程。这个流程主要依赖于 MyBatis 的核心组件,包括配置解析、SQL 映射器(Mapper)、动态 SQL 构建、SQL 执行以及结果映射等。下面是一个简化的过程描述,说明了 SqlSession 如何执行 Mapper 中的方法。

1. 获取 Mapper 接口的代理对象

当开发者调用 Mapper 接口中的方法时,实际上是通过 MyBatis 生成的代理对象来执行的。MyBatis 在创建 SqlSession 时会缓存 Mapper 接口的代理对象,这些代理对象在调用方法时会转发到 MyBatis 的内部机制上。

2. 解析 Mapper 接口

在 MyBatis 启动或 SqlSessionFactory 被创建时,MyBatis 会解析 Mapper 接口以及对应的 XML 映射文件(如果有的话)。这个过程中,MyBatis 会使用 Java 反射机制来查找 Mapper 接口中的方法,并将它们与 XML 映射文件中的 SQL 语句(或注解中的 SQL 语句)关联起来。

3. 构建 BoundSql

SqlSession 接收到 Mapper 方法的调用时,MyBatis 会根据方法名和参数类型查找之前解析的 Mapper 映射信息。然后,MyBatis 会构建 BoundSql 对象,这个对象包含了最终要执行的 SQL 语句、参数信息以及相关的映射信息。

  • 如果 Mapper 方法使用了 MyBatis 的注解(如 @Select@Insert 等),MyBatis 会直接解析这些注解来构建 SQL 语句。
  • 如果 Mapper 方法没有使用注解,而是依赖于 XML 映射文件,MyBatis 会根据 Mapper 接口中的方法名和 XML 文件中的 <select><insert> 等标签的 id 属性来匹配并构建 SQL 语句。

4. 参数替换和动态 SQL

在构建 BoundSql 的过程中,MyBatis 会处理 SQL 语句中的参数替换。如果 SQL 语句是动态的(即包含了条件判断、循环等),MyBatis 会使用动态 SQL 构建器来根据传入的参数值动态地构建最终的 SQL 语句。

5. 执行 SQL 语句

构建好 BoundSql 后,MyBatis 会使用 JDBC 连接来执行 SQL 语句。这个过程包括打开数据库连接(如果尚未打开)、设置 SQL 语句参数、执行 SQL 语句,并处理任何生成的 JDBC 结果集。

6. 结果映射

执行 SQL 语句后,MyBatis 会将 JDBC 结果集映射为 Java 对象。这个过程依赖于 Mapper 映射文件中定义的 <resultMap> 元素或方法注解中的结果映射信息。MyBatis 会根据这些信息将结果集中的列映射到 Java 对象的属性上。

7. 返回结果

最后,MyBatis 将映射后的 Java 对象返回给调用者。这个对象可能是单个实体、实体列表、Map 或其他类型,具体取决于 Mapper 方法的返回类型和 SQL 语句的查询结果。

需要注意的是,上述过程是一个简化的描述,MyBatis 的实际实现可能会更复杂,并且涉及到更多的细节和组件。此外,MyBatis 还提供了丰富的功能和插件扩展点,允许开发者根据需要自定义和扩展 MyBatis 的行为。

相关推荐
hello 早上好4 分钟前
05_Java 类加载过程
java·开发语言
echoVic17 分钟前
多模型支持的架构设计:如何集成 10+ AI 模型
java·javascript
橙露19 分钟前
Java并发编程进阶:线程池原理、参数配置与死锁避免实战
java·开发语言
echoVic21 分钟前
AI Agent 安全权限设计:blade-code 的 5 种权限模式与三级控制
java·javascript
PPPPickup23 分钟前
easymall---图片上传以及图片展示
java
历程里程碑25 分钟前
Linux 库
java·linux·运维·服务器·数据结构·c++·算法
Wpa.wk25 分钟前
接口自动化 - 接口鉴权处理常用方法
java·运维·测试工具·自动化·接口自动化
Pluchon28 分钟前
硅基计划4.0 简单模拟实现AVL树&红黑树
java·数据结构·算法
2501_9160088929 分钟前
深入解析iOS机审4.3原理与混淆实战方法
android·java·开发语言·ios·小程序·uni-app·iphone
wxin_VXbishe36 分钟前
C#(asp.net)学员竞赛信息管理系统-计算机毕业设计源码28790
java·vue.js·spring boot·spring·django·c#·php