MyBatis源码解析(一)——执行流程
原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/6603926.html
一、MyBatis 简介
MyBatis 框架是一种轻量级的 ORM 框架,当下十分流行,配合 Spring+Spring MVC 组成 SSM 框架,能够胜任几乎所有的 web 项目工程。
MyBatis 不同于 Hibernate 的最重要的地方就是 SQL 部分,MyBatis 中你可以自己编写灵活的 SQL 代码,而在 Hibernate 基本上将 SQL 代码封装起来的,几乎不会用到程序员去编写,这是 Hibernate 的优秀之处(简化了程序开发),同时也是其病脚(无法灵活开发)。
MyBatis 的轻量级是相对于 Hibernate 的重量级而言的,它并没有完全封装,将 SQL 的编写开放给程序员,虽然带来了复杂性,但是同时也带来了灵活性。而针对我们程序员而言,完全可以凭借技术来忽略这些复杂性,专注于其灵活性。
二、MyBatis 的执行流程
MyBatis 的执行流程如下图:
这张图是我的个人理解,参考了他人的成果,也带着自己的想法
解析:
Configuration.xml:该配置文件是 MyBatis 的全局配置文件,在这个文件中可以配置诸多项目,但是一般项目中,并不会配置太多内容,常用的内容是别名设置,拦截器设置等,至于环境设置与 Mapper 映射文件的注册会转移到 Spring 配置文件中(SSM 整合之后),而其余大部分的配置项都采用默认的配置。
XMLConfigBuilder:该类是 XML 配置构建者类,是用来通过 XML 配置文件来构建 Configuration 对象实例,构建的过程就是解析 Configuration.xml 配置文件的过程,期间会将从配置文件中获取到的指定标签的值逐个添加到之前创建好的默认 Configuration 对象实例中。
Configuration:该类是 MyBatis 的配置类,创建这个类的目的就是为了使用其对象作为项目全局配置对象,这样通过配置文件配置的信息可以保存在这个配置对象中,而这个配置对象在创建好之后是保存在 JVM 的 Heap 内存中的,方便随时读取。不然每次需要配置信息的时候都要临时从磁盘配置文件中获取,代码复用性差的同时,也不利于开发。
SqlSessionFactoryBuilder:该类是 SqlSessionFactory(会话工厂)的构建者类,之前描述的操作其实全是从这里面开启的,首先就是调用 XMLConfigBuilder 类的构造器来创建一个 XML 配置构建器对象,利用这个构建器对象来调用其解析方法 parse()来完成 Configuration 对象的创建,之后以这个配置对象为参数调用会话工厂构建者类中的 build(Configuration config) 方法来完成会话工厂对象的构建。
SqlsessionFactory:该接口是会话工厂,是用来生产会话的工厂接口,DefaultSqlSessionFactory 是其实现类,是真正生产会话的工厂类,这个类的实例的生命周期是全局的,它只会在首次调用时生成一个实例(单例模式),就一直存在直到服务器关闭。
openSession():在最后的 build(Configuration config) 方法中会返回一个 DefaultSqlSessionFactory 类的实例,这个类是 MyBatis 提供的默认会话工厂类,而我们使用的也正是这个类中的来 openSession() 方法来完成 SqlSession 对象的创建。
SqlSession:该接口是会话,是项目与数据库之间的会话,类似于客户端与服务器之间的会话(session),这个 SqlSession 的生命周期是方法级的,因为他是非线程安全的,针对每一次数据库访问都要创建一个 SqlSession,获取到返回结果之后,这个 SqlSession 就会被废弃。这区别于 SqlSessionFactory 的生命周期。
Executor:执行器接口,SqlSession 会话是面向程序员的,而内部真正执行数据库操作的却是 Executor 执行器,可以将 Executor 看作是面向 MyBatis 执行环境的,SqlSession 就是门面货,Executor 才是实干家。通过 SqlSession 产生的数据库操作,全部是通过调用 Executor 执行器来完成的。
StatementHandler:该类是 Statement 处理器,封装了 Statement 的各种数据库操作方法 execute(),可见 MyBatis 其实就是将操作数据库的 JDBC 操作封装起来的一个框架,同时还实现了 ORM 罢了。
ResultSetHandler:结果集处理器,如果是查询操作,必定会有返回结果,针对返回结果的操作,就要使用 ResultSetHandler 来进行处理,这个是由 StatementHandler 来进行调用的。这个处理器的作用就是对返回结果进行处理。
(未完待续)