第六章 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 的行为。

相关推荐
蓝-萧9 分钟前
使用Docker构建Node.js应用的详细指南
java·后端
多喝开水少熬夜18 分钟前
Trie树相关算法题java实现
java·开发语言·算法
lkbhua莱克瓦241 小时前
Java基础——集合进阶用到的数据结构知识点1
java·数据结构·笔记·github
音符犹如代码2 小时前
Java并发List实战:CopyOnWriteArrayList原理与ArrayList常见面试题
java·开发语言·面试·list
代码or搬砖2 小时前
Docker 部署 Java 项目实践
java·docker·容器
又是忙碌的一天2 小时前
抽象类和接口
java·开发语言
August_._2 小时前
【MySQL】SQL语法详细总结
java·数据库·后端·sql·mysql·oracle
Dxxyyyy2 小时前
零基础学JAVA--Day26(枚举类)
java·开发语言
黑屋里的马3 小时前
java的设计模式之桥接模式(Bridge)
java·算法·桥接模式
升鲜宝供应链及收银系统源代码服务3 小时前
升鲜宝生鲜配送供应链管理系统---PMS--商品品牌多语言存储与 Redis 缓存同步实现
java·开发语言·数据库·redis·缓存·开源·供应链系统