SqlSession build:

  

  ExecutorType :SIMPLE ,REUSE, BATCH,

    SIMPLE 为默认执行器;

    REUSE 为可重用执行器,重用Statement,执行器会缓存同一个sql Statement,不重复创建。

    BTACH 为批量更新执行器。会重用重用预处理语句,该模式下insert,update,delete的返回值将无意义,也可通过设置修改。

生命周期及作用域:

    SqlSessionFactoryBuilder: 方法作用域,该类用于创建SQLSessionFactory,一旦创建完后,就可以丢弃。

    SQLSessionFactory:应用作用域,创建后可在应用运行期间一直存在。不需要重复创建。适用于单例模式。

    SqlSession:请求或方法作用域,该类的实例是线程不安全的,因此用完之后即销毁;

  

  SQL执行流程:

    

  这里通过SQLSession中的selectList("statementId")方法查看主要的方法栈:

  

  其中包含了mybatis缓存处理、Intercepter(拦截器)的处理等操作。最终执行jdbc的Sql操作是由StatementHandler来完成。mybatis中sql mapper会转化为BoundSql,BoundSql包含了可执行sql,参数、参数类型等信息。

  StatementType : STATEMENT,PREPARED,CALLABLE

    STATEMENT: 直接执行sql,非预编译; 处理类:SimpleStatementHandler

    PREPARED:预编译处理;处理类:PreparedStatementHandler

    CALLABLE:执行存储过程;处理类:CallableStatementHandler

  StatementHandler:该接口有BaseStatementHandler和RoutingStatementHandler两个实现类。BaseStatementHandler 存在3个子类,分别对应StatementType的三种类型;BaseStatementHandler 中包含了ResultSetHandler和ParameterHandler

  StatementHandler执行sql后,会把结果交给ResultHandler来把查询结果转化为java对应的对象集合。handleResultSets()

  

 1   //处理ResultSet结果集
2 @Override
3 public List<Object> handleResultSets(Statement stmt) throws SQLException {
4 ErrorContext.instance().activity("handling results").object(mappedStatement.getId());
5 //用于存放查询的结果对象结合,多个ResultSet集合;每个Object对应一个ResultSet,每个Object对应的是一个List<Object>对象
6 //一般的查询只存在一个ResultSet,执行存储过程时会有多个ResultSet的情况,一般情况下multipleResults只有一个元素。
7 final List<Object> multipleResults = new ArrayList<Object>();
8
9 int resultSetCount = 0;
10 //获得第一个ResultSet对象 封装成ResultSetWrapper,主要包含了columnName、classNames、jdbcTypes
11 ResultSetWrapper rsw = getFirstResultSet(stmt);
12 //结构与multipleResults一致。
13 List<ResultMap> resultMaps = mappedStatement.getResultMaps();
14 //resultMapCount = 1
15 int resultMapCount = resultMaps.size();
16 validateResultMapsCount(rsw, resultMapCount);
17 while (rsw != null && resultMapCount > resultSetCount) {
18 //获得ResultMap对象
19 ResultMap resultMap = resultMaps.get(resultSetCount);
20 //处理ResultSet,将结果添加到multipleResults中
21 handleResultSet(rsw, resultMap, multipleResults, null);
22 //获取下一个ResultSet,并封装成ResultSetWrapper
23 rsw = getNextResultSet(stmt);
24 //清理
25 cleanUpAfterHandlingResultSet();
26 resultSetCount++;
27 }
28 //多个ResultSet结合情况下,执行存储过程时会使用
29 String[] resultSets = mappedStatement.getResultSets();
30 if (resultSets != null) {
31 while (rsw != null && resultSetCount < resultSets.length) {
32 ResultMapping parentMapping = nextResultMaps.get(resultSets[resultSetCount]);
33 if (parentMapping != null) {
34 String nestedResultMapId = parentMapping.getNestedResultMapId();
35 ResultMap resultMap = configuration.getResultMap(nestedResultMapId);
36 handleResultSet(rsw, resultMap, null, parentMapping);
37 }
38 rsw = getNextResultSet(stmt);
39 cleanUpAfterHandlingResultSet();
40 resultSetCount++;
41 }
42 }
43
44 return collapseSingleResultList(multipleResults);
45 }
handleResultSet()
 1   //处理
2 private void handleResultSet(ResultSetWrapper rsw, ResultMap resultMap, List<Object> multipleResults, ResultMapping parentMapping) throws SQLException {
3 try {
4 if (parentMapping != null) {
5 //适用于存储过程,多个ResultSet的情况
6 handleRowValues(rsw, resultMap, null, RowBounds.DEFAULT, parentMapping);
7 } else {
8 //如果没有自定义ResultHandler,则使用DefaultResultHandler
9 if (resultHandler == null) {
10 DefaultResultHandler defaultResultHandler = new DefaultResultHandler(objectFactory);
11 handleRowValues(rsw, resultMap, defaultResultHandler, rowBounds, null);
12 multipleResults.add(defaultResultHandler.getResultList());
13 } else {
14 //处理ResultSet的每一行结果
15 handleRowValues(rsw, resultMap, resultHandler, rowBounds, null);
16 }
17 }
18 } finally {
19 // issue #228 (close resultsets)
20 closeResultSet(rsw.getResultSet());
21 }
22 }

Mybatis日记的更多相关文章

  1. MyBatis日记(五):一对一关系,一对多关系

    一对一关系: 首先在数据库中新增地址表(t_address)用于存储人员的地址信息: CREATE TABLE `t_address` ( `id` ) NOT NULL AUTO_INCREMENT ...

  2. MyBatis日记(四):MyBatis——insert、update、delete、select

    MyBatis简单增删改查操作,此处所做操作,皆是在之前创建的MyBatis的Hello world的工程基础上所做操作. 首先在接口文件(personMapper.java)中,添加操作方法: pa ...

  3. myBatis 日记

    一级缓存默认开启, 有效范围是在当前sqlsession, 同一个SqlSession对象执行相同的sql并参数也要相同,缓存才有效. 在同一个会话里面,多次执行相同的SQL 语句,会直接从内存取到缓 ...

  4. mybatis日记配置Log4j

    拷贝log4j-1.2.16.jar到项目lib下 方式一是在src下新建一个log4j.xml文件,其具体内容如下 <?xml version="1.0" encoding ...

  5. MYbatis调试日记(三)

    如何在Mybatis中插入日期类型的数据 直接见代码: xml配置文件 java代码

  6. mybatis学习日记-day01

    Mybatis说明: MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(Plain Old Java Objects,普通的 Java对象)映射成数据库中的 ...

  7. MyBatis学习日记(三):戏说MyBatis配置文件

    properties标签 properties标签可以用来加载别的配置文件,比如可以加载数据库的配置文件,jdbc.properties. 下面是jdbc.properties jdbc.driver ...

  8. MyBatis学习日记(二): MyBatis Say Hello

    首先在Eclipse中创建一个maven工程: 在maven工程下的pom.xml文件中添加MyBatis.MySQL.Junit依赖: <project xmlns="http:// ...

  9. MyBatis学习日记(一):拜见小主——MyBatis

    近日学习MyBatis,特将学习过程及一点心得记录于此. MyBatis为何物? MyBatis 是支持定制化SQL.存储过程以及高级映射的优秀的持久层框架.MyBatis 避免了几乎所有的 JDBC ...

随机推荐

  1. 05 C语言的数据类型

    C语言的数据类型 在C 中,数据类型是用来声明不同类型的变量或函数的一个广泛的概念.变量的数据类型决定了变量存储占用的空间大小,以及如何去解释存储的位模式. C 中的数据类型可分为以下几大类: 序号 ...

  2. Python实现的数据结构与算法之队列详解

    本文实例讲述了Python实现的数据结构与算法之队列.分享给大家供大家参考.具体分析如下: 一.概述 队列(Queue)是一种先进先出(FIFO)的线性数据结构,插入操作在队尾(rear)进行,删除操 ...

  3. windows.h系统函数

    转载:https://blog.csdn.net/u010756046/article/details/82432312 // Windows系统函数.cpp: 定义控制台应用程序的入口点.// #i ...

  4. P2652 同花顺

    P2652 同花顺 Link 题目背景 所谓同花顺,就是指一些扑克牌,它们花色相同,并且数字连续. 题目描述 现在我手里有 \(n\) 张扑克牌,但它们可能并不能凑成同花顺.我现在想知道,最少更换其中 ...

  5. angular http 跨域访问

    1.在跟目录中创建配置文件:proxy.config.json ,文件内容如下: { "/api": { "target": "http://192. ...

  6. 关于Elasticsearch版本升级,Kibana报index迁移与需要x-pack插件问题

    关于Elasticsearch版本升级,Kibana报index迁移与需要x-pack插件问题 这个问题是由于elasticsearch旧版残留文件导致,使用下述指令删除即可 查看所有elastics ...

  7. 实验 6:OpenDaylight 实验——OpenDaylight 及 Postman 实现流表下发

    一.实验目的 熟悉 Postman 的使用:熟悉如何使用 OpenDaylight 通过 Postman 下发流表. 二.实验任务 流表有软超时和硬超时的概念,分别对应流表中的 idle_timeou ...

  8. Linux中断驱动程序

    1.中断概念 中断时一种电信号,由硬件设备产生,然后再由中断控制器向处理器发送相应的信号.处理器一经检测到该信号,便中断自己当前正在处理的工作,转而去处理中断.此后,处理器会通知操作系统已经产生中断. ...

  9. 利用github创建个人网站

    先建个仓库,仓库名为: 用户名.github.io 进入仓库,删除README.md文件 新建个文件,文件名为: index.html,内容根据自己要求编写 打开网站,地址:https://用户名.g ...

  10. kafka伪集群搭建

    https://blog.csdn.net/zxy987872674/article/details/72466504