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

相关推荐
帅气的你5 分钟前
Spring Boot 集成 AOP 实现日志记录与接口权限校验
java·spring boot
zhglhy25 分钟前
Spring Data Slice使用指南
java·spring
win x37 分钟前
Redis 主从复制
java·数据库·redis
weixin_423995001 小时前
unity 处理图片:截图,下载,保存
java·unity·游戏引擎
帅气的你1 小时前
从零封装一个通用的 API 接口返回类:统一前后端交互格式
java·设计模式
qq_178057071 小时前
基于minio实现的分片上传-支持断点续传
java
高山上有一只小老虎1 小时前
灵异背包?
java·算法
码农水水1 小时前
大疆Java面试被问:TCC事务的悬挂、空回滚问题解决方案
java·开发语言·人工智能·面试·职场和发展·单元测试·php
qq_2518364571 小时前
基于java Web 个人网站系统设计与实现
java·开发语言·数据库
帅气的你1 小时前
Spring Boot 1.x 接口性能优化:从 3 秒到 200 毫秒的实战调优之路
java·spring boot