Mybatis源码剖析 -- 架构原理

一、架构设计

Mybatis 的功能架构分为三层

  1. API 接口层
    提供给外部使用的接口 API,开发人员通过这些本地 API 来操作数据库。接口层⼀接收
    到调用请求就会调用数据处理层来完成具体的数据处理
    MyBatis 和数据库的交互有两种方式
    • 使用传统的 MyBatis 提供的API
    • 使用 Mapper 代理的方式
  2. 数据处理层
    负责具体的 SQL查找、SQL解析、SQL执行和执行结果映射处理等。它主要的目的是根据调用的请求完成⼀次数据库操作
  3. 基础支撑层
    负责最基础的功能支撑,包括连接管理、事务管理、配置加载和缓存处理,这些都是
    共用的东西,将他们抽取出来作为最基础的组件。为上层的数据处理层提供最基础的支撑


二、主要构件及其相互关系

构件 描述
SqlSession 作为 MyBatis 工作的主要顶层API,表示和数据库交互的会话,完成必要数据库增删改查功能
Executor MyBatis执行器,是 MyBatis 调度的核心,负责SQL语句的生成和查询缓存的维护
StatementHandler 封装了 JDBC Statement 操作,负责对 JDBC statement 的操作,如设置参数、将 Statement 结果集转换成 List 集合
ParameterHandler 负责对用户传递的参数转换成 JDBC Statement 所需要的参数
ResultSetHandler 负责将 JDBC 返回的 ResultSet 结果集对象转换成 List 类型的集合
TypeHandler 负责 java 数据类型和 JDBC 数据类型之间的映射和转换
MappedStatement MappedStatement 维护了⼀条<select | update | delete | insert>节点的封装
SqlSource 负责根据用户传递的 parameterObject,动态地生成SQL语句,将信息封装到 BoundSql 对象中,并返回
BoundSql 表示动态生成的SQL语句以及相应的参数信息

三、总体流程

  1. 加载配置并初始化,将核心配置文件内容解析封装到 Configuration,将 SQL 的配置信息加载成为⼀个 mappedStatement 对象,存储在内存之中
    • 触发条件:加载配文件
    • 配置来源于两个地方:
      ① 配置文件(核心配置文件conf.xml,mapper文件*.xml)
      ② java 代码中的注解
  2. 接收调用请求
    • 触发条件:调用 Mybatis 提供的API
    • 传入参数:为 SQL 的 ID 和传入参数对象
    • 处理过程:将请求传递给下层的请求处理层进行处理
  3. 处理操作请求
    • 触发条件:API接口层传递请求过来
    • 传入参数:为 SQL 的 ID 和传入参数对象
    • 处理过程:
      ① 根据 SQL 的 ID 查找对应的 MappedStatement 对象
      ② 根据传入参数对象解析 MappedStatement 对象,得到最终要执行的 SQL 和执行传入参数
      ③ 获取数据库连接,根据得到的最终 SQL 语句和执行传入参数到数据库执行,并得到执行结果
      ④ 根据 MappedStatement 对象中的结果映射配置对得到的执行结果进行转换处理,并得到最终的处理结果
      ⑤ 释放连接资源
  4. 返回处理结果

你可能感兴趣的:(Mybatis源码剖析 -- 架构原理)