《MyBatis技术内幕(徐郡明)》学习笔记(持续更新……)

        本文是我自己在秋招复习时的读书笔记,整理的知识点,也是为了防止忘记,尊重劳动成果,转载注明出处哦!如果你也喜欢,那就点个小心心,文末赞赏一杯豆奶吧,嘻嘻。 让我们共同成长吧……


第1章  MyBatis快速入门

1.1  ORM简介

    JDBC是Java与数据库交互的统一API.传统的JDBC编程的操作步骤如下:

        (1)、注册数据库驱动,明确指定数据库URL地址、数据库用户名、密码等连接信息

        (2)、通过DriverManager打开数据库连接

        (3)、通过数据库连接创建Statement对象

        (4)、通过Statement对象执行SQL语句,得到ResultSet对象

        (5)、通过ResultSet读取数据,并将数据转换成JavaBean对象

        (6)、关闭ResultSet、Statement对象以及数据库连接,释放相关资源

    ORM(Object Relational Mapping)对象关系映射,将JavaBean和数据库对象进行相互的转换。

1.2  常见持久化框架

    Hibernate、MyBatis、JPA、Spring JDBC

1.3 MyBatis示例


mybatis-config.xml配置与xml映射文件的配置,参见http://www.mybatis.org/mybatis-3/zh/configuration.html

1.4  Mybatis整体架构

    MyBatis整体分为三层:基础支持层、核心处理层、接口层

《MyBatis技术内幕(徐郡明)》学习笔记(持续更新……)_第1张图片

1、基础支持层

    基础支持层含有整个mybatis的基础模块,这些模块为核心处理层提供了良好的支撑。

(1)反射模块

        mybatis提供了反射模块,该模块对java原生反射进行了良好封装。

(2)类型转换模块

        mybatis为简化配置文件提供了别名机制,该机制是类型转换模块的主要功能之一。另一个功能是实现JDBC类型和Java类型之间的转换,该功能在为SQL语句绑定实参以及映射查询结果集时会涉及。在为sql语句绑定实参的时候,会将数据由java类型转换为JDBC类型,而在映射结果集的时候,会将数据由JDBC类型转化为Java类型。

(3)日志模块

        良好日志可以帮助开发测试人员迅速定位BUG代码,目前有很多优秀日志框架例如log4j、log4j2、slf4j等

(4)资源加载模块

        主要是对类加载器进行封装,确定类加载器的使用顺序,并提供加载类文件一起其他资源文件的功能

(5)解析器模块

        功能有二:一是对XPath进行封装,为MyBatis初始化时解析mybatis-config.xml配置文件提供支持;再者就是为处理动态SQL的占位符提供支持。

(6)数据源模块

(7)事务管理

(8)缓存模块:

(9)Binding模块:

2、核心处理层

    在核心处理层中实现了mybatis的核心处理流程,其中包括mybatis的初始化以及完成一次数据库操作的所有流程。

(1)配置解析

    在mybatis的初始化过程中,会加载mybatis-config.xml配置文件、映射配置文件以及Mapper接口中的注解信息,解析后的配置信息会形成相应的对象存在Configuration对象中。例如节点(即ResultSet的映射规则)会被解析成ResultMap对象,节点会被解析成ResultMapping对象,之后利用该Configuration对象创建SqlSessionFactory对象。等Mybatis初始化以后,开发人员可以通过初始化得到SqlSessionFactory创建SqlSession对象完成数据库操作。

(2)SQL解析和scripting模块

    MyBatis实现动态SQl语句功能,提供了多种动态SQL对应的节点(where、if、foreach等),通过这些节点的使用,可以写出动态SQL语句。

    mybatis中的scripting模块会根据用户传入的参数,解析映射文件中定义的动态SQL节点,并形成数据库可以执行的Sql语句,之后会处理SQL语句中的占位符,绑定用户传入的实参。

(3)SQL执行

    SQL语句的执行涉及对个组件,其中比较重要的是Executor,StatementHandler,ParameterHandler和ResultSetHandler。Executor主要负责一级缓存和二级缓存,并提供是事务管理的相关操作,它会将数据库相关操作委托给StatementHandler完成,StatementHandler首相通过ParammeterHandler完成SQL的实参绑定,然后通过java.sql.Statement对象执行sql语句并得到结果集ResultSet,最后通过ResultSetHandler完成结果集的映射,得到对象并返回。如下图所示:


《MyBatis技术内幕(徐郡明)》学习笔记(持续更新……)_第2张图片

(4)插件

    mybatis提供了插件接口,我们可以使用插件来对mybatis进行扩展。

3、接口层

    接口层的核心是SqlSession接口,该接口定义了Mybatis保留给应用的API,也就是上层应用和Mybatis交互的桥梁。接口层在接收到调用请求时,会调用核心处理层的相应模块完成具体的数据库操作。

第2章  基础支持层

    本章介绍MyBatis中的基础支持层的功能。

《MyBatis技术内幕(徐郡明)》学习笔记(持续更新……)_第3张图片

2.1  解析器模块

   2.1.1 XPath简介

     XML解析方式:DOM(Document Object Model)解析(MyBatis默认)、SAX(Simple API for XML)解析、StAX(Streaming API for XML)解析。

    MyBatis采用DOM方式,使用XPath解析Mybatis初始化中的mybatis-confgi.xml配置文件和映射文件。

    XPath常用的表达式: nodename、 /   、  //   、  .    、...  、 @ 、 *  、 @* 、node() 、 text() 、 | 、[]

    2.1.2  XPathPaser

      MyBatis提供的XPathParser类封装了XPath、Document、EntityResolver。

    XPathPaser各个字段的含义:

        private  Document document;    //Document对象

        private boolean validation;    //是否开启验证

        private EntityResolver  entityResolver ;    //用于加载本地DTD文件

        private Properties varables;    //mybatis-config.xml文件中的标签对应的键值对集合

        private XPath xpath;    //XPath对象

    XMlmapperEntityResolver 是MyBatis中EntityResolver接口的实现,EntityResolver接口的核心方法是resolveEntity()方法。

    在XPathParser.createDocument()方法中封装了创建Document对象的过程并处罚了加载XML文档的过程。

    XPathParser提供了一些列的eval*()方法用于解析boolean、short、long、int、String、Node等类型的信息,他通过调用前面介绍的XPath.evaluate()方法查找指定路径的节点或者属性,并进行相应的类型转换。需要注意XPathParser.evalString()方法会调用PropertyPaser.parse()方法处理节点相应的默认值。在PropertyPaser中指定了是否开启默认功能以及默认的分割符。PropertyPaser.parse()方法会创建GenericTokenParser解析器(一个通用的字占位符解析器),将默认值的处理委托给GenericTokenParser.parser()方法,将解析得到的占位符的字面值,交给TokenHandler处理,然后将解析结果重新拼装成字符创并返回。

    XPathParser.evalNode()返回值类型是XNode,XNode提供了多种get*()方法获得所需的节点信息。

2.2  反射工具箱

    2.2.1  Reflector&ReflectorFactory

     每个Reflector对象都对应一个类,在Reflector中缓存了反射操作需要使用的类的信息






























































?xml version="1.0" encoding="utf-8"?

你可能感兴趣的:(《MyBatis技术内幕(徐郡明)》学习笔记(持续更新……))