二、源码分析之mybatis基础架构

前面我们学习了mybatis的基本用法,但是作为优秀的开发者不能止步于用,要"知其然,知其所以然"。本系列博文将对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完成结果集映射,得到结果对象并返回。

执行sql简单流程图

(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维护了一条节点的封装;

  • SqlSource:负责根据用户传递的parameterObject,动态地生成SQL语句,将信息封装到BoundSql对象中,并返回;

  • BoundSql:表示动态生成的SQL语句以及相应的参数信息;

  • Configuration:MyBatis所有的配置信息都维持在Configuration对象之中;

mybatis核心类之间的关系

参考:
《mybatis技术内幕》

你可能感兴趣的:(二、源码分析之mybatis基础架构)