转载请注明来自:http://www.cnblogs.com/xmzJava/p/8578399.html

日常开发中,mybatis如果报错了调错起来会比较麻烦,因为一层套着一层,如果没有对mybatis有整体的认识,很容易迷失其中,今天我们大致的把mybatis的流程梳理一遍,看一下一次正常的sql操作,内部究竟发生了什么。

SqlSessionFactory


 static {
try {
reader = Resources.getResourceAsReader("mybatis/config.xml");
sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
}
catch (IOException e) {
e.printStackTrace();
}
}

我们先来看上述两行代码,mybatis请求数据库前,需要读取配置文件的信息,然后构建出一个SqlSessionFactory。我们从第三行代码开始

方法很简单,将配置文件的路劲转为流返回

再看第四行的build方法

看到 XMLConfigBuilder ,顾名思义就是通过流,解析xml的配置文件。

我们看下是怎么解析的

这是构造方法

跳转到XpathPather

第一行的 commonConstructor:将validation、variables、entityResolver设置到XPathParser类的参数中而已,顺便再实例化一个javax.xml.xpath.XPath出来,XPath用于在XML文档中通过元素和属性进行导航,并对元素和属性进行遍历。

重点在第二行:将XML配置文件转化为Document对象,我们看下具体实现

前半部分是验证,重点在最后解析这边:

我们回到最前面

现在第一行的作用已经很清楚了,解析xml配置文件并将Document存储到XPathParser中

我们再看第二行的parse方法

可以看到使用XPathParser的evalNode方法解析标签,后面解析标签会大量用到此方法,此方法将标签解析为XNode

重点在parseConfiguration中,点进去看看

很明显可以看到,这里要做的是把配置文件的各个节点进行解析,并将数据设置到相应的对象中去。

这些解析方法我们本次不深入探讨

我们再回到最前面

前面一系列流程简单的总结就是,读取xml文件到Document,再解析Document到Configuration

等于现在所有的配置工作都做好了,我们看下build方法

最终,构建出来了一个DefaultSqlSessionFactory。

SqlSession


经过上述一系列的解析配置,我们的准备工作终于做好了,现在我们来看下以下代码

 SqlSession ss = sqlSessionFactory.openSession();
try {
int rows = ss.insert("SQL");
ss.commit(); } catch (Exception e) {
ss.rollback();
return 0;
} finally {
ss.close();
}

几行代码就完成了一次数据库的插入,现在我们就看看mybatis到底是怎么实现的

从第一行开始分析:获得sqlsession

我们再看下newExecutor的方法

返回不同类型的执行器,mybatis的缓存开关在这里就有提现。

再看第三行:

得到DefaultSqlSession后,我们开始执行我们的sql了

在mybatis中,其实就两种操作:查询与修改,新增和删除其实只是特殊的修改

我们先看 getMappedStatement,

在之前xml解析中,mybatis会自动的把每一个sql语句但是当做一个MappedStatement放到一个map中,key是namespace作为前缀,再加上该节点本身的id值。

具体信息可以点击这边

再下一行,这里把参数做了层包装,就开始执行sql了,具体内容下篇继续

参考:


http://www.cnblogs.com/xrq730/p/6824030.html

https://my.oschina.net/lichhao/blog/114311

Mybatis 源码简述的更多相关文章

  1. Mybatis源码学习之DataSource(七)_1

    简述 在数据持久层中,数据源是一个非常重要的组件,其性能直接关系到整个数据持久层的性能.在实践中比较常见的第三方数据源组件有Apache Common DBCP.C3P0.Proxool等,MyBat ...

  2. Mybatis源码学习之整体架构(一)

    简述 关于ORM的定义,我们引用了一下百度百科给出的定义,总体来说ORM就是提供给开发人员API,方便操作关系型数据库的,封装了对数据库操作的过程,同时提供对象与数据之间的映射功能,解放了开发人员对访 ...

  3. 精尽MyBatis源码分析 - MyBatis-Spring 源码分析

    该系列文档是本人在学习 Mybatis 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释(Mybatis源码分析 GitHub 地址.Mybatis-Spring 源码分析 GitHub ...

  4. 精尽MyBatis源码分析 - Spring-Boot-Starter 源码分析

    该系列文档是本人在学习 Mybatis 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释(Mybatis源码分析 GitHub 地址.Mybatis-Spring 源码分析 GitHub ...

  5. MyBatis源码分析(一)开篇

    源码学习的好处不用多说,Mybatis源码量少.逻辑简单,将写个系列文章来学习. SqlSession Mybatis的使用入口位于org.apache.ibatis.session包中的SqlSes ...

  6. MyBatis源码分析-MyBatis初始化流程

    MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以对配置和原生Map使用简 ...

  7. MyBatis源码分析-SQL语句执行的完整流程

    MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以对配置和原生Map使用简 ...

  8. MyBatis源码分析-IDEA新建MyBatis源码工程

    MyBatis 是支持定制化 SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以对配置和原生Map使用简 ...

  9. MyBatis源码分析(5)——内置DataSource实现

    @(MyBatis)[DataSource] MyBatis源码分析(5)--内置DataSource实现 MyBatis内置了两个DataSource的实现:UnpooledDataSource,该 ...

随机推荐

  1. csu1804

    /* csu 1804 因为define和const总出错,到现在也不明白为什么 不知道define 和 const 出来的 mod 有什么区别 */ #include<iostream> ...

  2. idea设置utf-8

  3. ApocalypseSomeday

    ApocalypseSomeday CountDownLatch和CyclicBarrier分别都是在什么时候使用的? Charles使用(apphttp抓包,request拦截,response拦截 ...

  4. #2019-2020-4 《Java 程序设计》第八周总结

    2019-2020-4 <Java 程序设计>第八周知识总结 第15章:泛型与集合框架 一.泛型 1.泛型(Generics)是可以建立具有类型安全的集合框架,如链表.散列映射等数据结构: ...

  5. HCNA之网络通信基础

    一.通信与网络 通信的概念我们并不陌生,在人类社会的起源和发展过程中,通信就直伴随着我们.般认为, 20世纪七.八十年代,人类社会已进入到信息时代,对于生活在信息时代的我们,通信的必要性和重要性更是不 ...

  6. java构建树形菜单递归工具类

    1.设计菜单实体 import java.util.List; public class Menu { //菜单id private Long id; //父节点id private Long par ...

  7. 3、MHC主要组织相容性复合体

    主要组织相容性复合体 (major histocompatibility complex MHC) 位于脊椎动物某对染色体上紧密连锁的基因群,其编码的蛋白是主要组织相容性抗原,是移植排斥反应的主要抗原 ...

  8. Monkey测试结果分析

    Monkey测试结果分析 什么是monkey Monkey 测试是 Android 自动化测试的手段之一,它通过模拟用户的按键输入.触摸屏输入等,测试设备多长时间出现异常.Monkey 是一个命令行工 ...

  9. admob sdk

    https://support.google.com/admob/answer/2993059?hl=zh-Hans admob sample http://china.inmobi.com/sdk/ ...

  10. SQL Server Integration Services SSIS最佳实践

    SQL Server Integration Services Best Practices Tips https://www.mssqltips.com/sql-server-tip-categor ...