Mybatis工作流程

Posted ericz2j

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Mybatis工作流程相关的知识,希望对你有一定的参考价值。

Mybatis体系结构:

技术图片

Mybatis的功能架构分为三层:

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

Mybatis工作流程
1、加载配置
配置有两种方式,一种是XML文件配置,另一种是java代码的注解。Mybatis将sql的配置信息加载成为 一个个的MappedStatement对象(包括了传入参数映射配置,执行事物SQL语句,结果映射配置),将其 存储再内存中。

2、Sql解析
当API接口层接收到调用请求时,会接收传入sql的Id和传入对象(可以是Map,javaBean或者基本数 据类型),Mybatis会根据Sql的的Id查找到相应的的MappedStatement,然后根据传入的参数对象对
MappedStatement对象进行解析,解析后便得到了最终需要执行的Sql语句和参数。

3、Sql执行
将最终得到的Sql和参数拿到数据库进行执行,得到需要的结果。

4、结果映射
将操作得到的数据库的结果按照映射配置进行转换,可以将其转换成HashMap,javaBean 或者基本数据类型,并将最终的结果返回。

Mybatis核心部件

  1. Configuration :MyBatis所有的配置信息都保存在Configuration对象之中,配置文件中的大部分配置都会存 储到该类中
  2. SqlSession :作为MyBatis工作的主要顶层API,表示和数据库交互时的会话,完成必要数据库增删改查功能
  3. Executor :MyBatis执行器,是MyBatis 调度的核心,负责SQL语句的生成和查询缓存的维护,有他来实现真 正对数据库的操作。
  4. StatementHandler :封装了JDBC Statement操作,负责对JDBC statement 的操作,如设置参数等
  5. ParameterHandler : 负责对用户传递的参数转换成JDBC Statement 所对应的数据类型
  6. ResultSetHandler : 负责将JDBC返回的ResultSet结果集对象转换成List类型的集合
  7. TypeHandler: 负责java数据类型和jdbc数据类型(也可以说是数据表列类型)之间的映射和转换
  8. MappedStatement : 其维护着一条<select | update| delete| insert>节点的封装 (就是我们map.xml中定 义哪些操作)

以上是关于Mybatis工作流程的主要内容,如果未能解决你的问题,请参考以下文章

02-Mybatis工作原理

mybatis工作流程

Java框架MyBatis工作流程是怎样的?

mybatis执行流程

MyBatis的几个重要概念和工作流程

mybatis执行流程