在 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 的行为。