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来进行调用的。这个处理器的作用就是对返回结果进行处理。

我的理解:SqlSessionFactoryBuilder是mybatis的核心,所有的功能都是通过SqlSessionFactoryBuilder来完成的。

1.SqlSessionFactoryBuilder调用XMLConfigBuilder来解析Configuration.xml中配置的内容

2.解析出配置内容之后生成对应的配置类Configuration

3.通过自身的build方法来生成SqlsessionFactory会话工厂

4.SqlsessionFactory会去创建Sqlsession用于sql语句的执行

5.Sqlsession中真正执行sql的类是Executor的实现类,在SqlsessionFactory创建Sqlsession的时候会创建Executor的实现类,并且将Executor设置进Sqlsession中

6.真正的操作数据的类是StatementHandler的实现类,此类封装了各种与数据库交互的方法

7.在StatementHandler执行完sql语句之后,ResultSetHandler用来将结果集进行处理,封装到model类中

  (未完待续)

猜你喜欢

转载自blog.csdn.net/linhui258/article/details/83026300