前面我们学习了mybatis的基本用法,但是作为优秀的开发者不能止步于用,要"知其然,知其所以然"。本系列博文将对mybatis源码进行深入剖析,让其深刻的理解mybatis内部的运行机制。
一、mybatis架构简介
以上是mybatis的基础架构图,下面针对图中的众多的组件进行简单的介绍。
1、引导层
- 引导层主要是关于myabtis的配置相关,mybatis提供了两种方式进行配置:一种是采用硬编码方式,基于Java API完成的;一种是基于xml配置方式完成的。由于硬编码受灵活性限制,实际运用中通常是使用xml的配置方法对myabtis进行配置。
2、基础支持层
- 该层包含整个mybatis的基础模块,这些模块为核心处理层的功能提供了良好的支撑
(1)反射模块
myabtis提供了反射模块,该模块对java原生的反射进行了良好的封装,提供了更加简洁易用的API,同时对反射进行了一系列的优化,比如缓存了类的元数据。
(2)类型转换模块
类型转换功能之一就是为简化配置文件提供了别名机制;类型转换另一个功能就是实现JDBC与JAVA类之间的转换(在sql语句绑定参数与映射结果集时候涉及比较多)
(3)日志模块
集成众多的第三方日志框架
(4)资源加载模块
资源加载模块主要是对类加载器进行了封装,确定类加载器的使用顺序,并提供了加载文件以及其他资源文件的功能
(5)解析器模块
解析器模块主要提供了两个功能:一个是对xpath的封装,解析config和mapper配置文件;另一个是提供处理动态的sql语句中的占位符号的支持
(6)数据源模块
提供了相应的数据源实现,同时提供了与第三方数据源集成的接口
(7)事物管理
mybatis对数据库的事物做了抽象,其自身提供了相应的事务接口和简单实现。但是通常是与spring集成,并由spring框架管理事务
(8)缓存模块
mybatis提供了一级和二级缓存,这两级缓存是依赖于基础支持层中的缓存模块实现的
(9)binding模块
mybatis通过binding模块将用户自定义的mapper接口与映射配置文件关联起来,系统可以通过调用自定义的mappe接口中的方法进行执行相应的sql语句完成数据库操作
3、核心处理层
- 核心处理层是mybatis的核心处理流程,其中包括mybatis的初始化以及完成一次数据库操作的涉及的全部流程也难怪
(1)配置解析
在mybatis初始化过程中,会加载config配置文件和mapper映射文件及mapper接口中的注解信息,解析后的配置信息会形成相应的对象保存到Configuration中。然后利用configuration对象创建sqlSessionFactory对象,在创建SqlSession对象,进而完成数据库的操作。
(2)Sql解析与scripting模块
mybatis实现了动态sql语句的功能,通过sql语句的解析,完成动态灵活sql的需求。mybatis中的scripting模块会根据用户传入的实际参数,解析映射文件中定义的动态sql节点,并形成数据库可执行的sql语句。
(3)sql语句执行
整个sql语句执行过程中比较重要的是Executor、statementHandler、ParameterHandler和ResultSetHandler
1、Executor主要负责一级缓存和二级缓存及事物相关操作,并将数据库相关操作委托给StatementHandler完成
2、StatementHandler首先通过ParameterHandler完成Sql语句的参数绑定,然后通过java原生的Statement对象执行Sql语句并得到结果集,然后通过ResultSetHandler完成结果集映射,得到结果对象并返回。
(4)插件
用户可以通过插件的方式对mybatis进行扩展,用户自定义的插件可以改变mybatis的默认行为。在使用自定义插件之前需要了解mybatis的内部原理,才能编写出高效、安全的插件
4、接口层
- 接口层核心就是SqlSession接口,该接口定义了Mybatis暴露给应用程序使用的API。
二、mybatis重要组件分析
上面我们分析了mybatis的架构,知道了mybatis是由哪些组件组成的以及对组件做了简单的介绍。但作为源码分析,上面提高的内容并非全部是重点,mybatis框架中重点要关注的其实就10几个类,好好理解这10几个类,然后做一个串联,理清运行流程,基本就能读懂mybatis原理了。下面我将重点罗列出要关注的类:
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语句以及相应的参数信息;
Configuration:MyBatis所有的配置信息都维持在Configuration对象之中;
参考:
《mybatis技术内幕》