在学习了MyBatis环境搭建和入门程序的编写之后,可结合1.4节MyBatis入门程序,对MyBatis操作数据库的流程进行分析,如图1-6所示。
图1-6 MaBatis的工作流程
在图1-6中,MyBatis操作数据库的流程分为8个步骤,具体介绍如下。
(1)MyBatis读取核心配置文件mybatis-config.xml
mybatis-config.xml核心配置文件主要配置了MyBatis的运行环境等信息。
(2)加载映射文件Mapper.xml
Mapper.xml文件即SQL映射文件,该文件配置了操作数据库的SQL语句,需要在mybatis-config.xml中加载才能执行。mybatis-config.xml可以加载多个映射文件,每个映射文件对应数据库中的一张表。
(3)构造会话工厂
通过MyBatis的环境等配置信息构建会话工厂SqlSessionFactory,用于创建SqlSession。
(4)创建会话对象
由会话工厂SqlSessionFactory创建SqlSession对象,该对象中包含了执行SQL语句的所有方法。
(5)创建执行器
会话对象本身不能直接操作数据库,MyBatis底层定义了一个Executor接口用于操作数据库,执行器会根据SqlSession传递的参数动态的生成需要执行的SQL语句,同时负责查询缓存地维护。
(6)封装SQL信息
SqlSession内部通过执行器Executor操作数据库,执行器将待处理的SQL信息封装到MappedStatement对象中,MappedStatement对象中存储了要映射的SQL语句的id、参数等。Mapper.xml文件中一个SQL语句对应一个MappedStatement对象,SQL语句的id即是MappedStatement的id。Executor执行器会在执行SQL语句之前,通过MappedStatement对象将输入的参数映射到SQL语句中。
(7)操作数据库
根据动态生成的SQL操作数据库。
(8)输出结果映射
执行SQL语句之后,通过MappedStatement对象将输出结果映射至Java对象中。
通过上面对MyBatis框架工作原理的讲解,相信读者对MyBatis框架已经有了一个初步的了解。对于初学者来说,上面所讲解的内容可能无法完全理解,现阶段也不要求读者能完全理解,这里讲解MyBatis框架的工作原理是为了方便后续的学习,读者能够了解MyBatis的工作原理和执行流程即可。