Mybatis核心模块简介
Configuration
主要字段
Environment:配置DataSource和TransactionFactory
ObjectFactory:bean工厂
MapperRegistry:Mapper的注册器,用Map存放class与MapperProxyFactory的映射
InterceptorChain:插件链
TypeHandlerRegistry:TypeHandler的注册器,用Map存放jdbcType、Type与TypeHandler的映射
mappedStatements:存放StatementId与MapperStatement的映射
resultMaps:存放ResultMap
parameterMaps:存放ParameterMap
loadedResource:已加载的资源,包括xml和Mapper接口
主要方法:
addMappedStatement:注册mapperStatement
addMapper:添加Mapper到MapperRegistry中,同时解析Mapper的注解和对应的xml获取MapperStatement
getMapper:获取mapper代理
mapper解析流程

SqlSessionFactoryBuilder
build:读取xml配置构建configuration,实例化SqlSessionFactory
解析xml配置主要流程:
1.解析plugin注册到configuration.addIntercptor
2.解析objectFactory注册到configuration.setObjectFactory(factory);
3.解析objectWrapperFactory注册到configuration.setObjectWrapperFactory(factory);
4.解析environments创建datasource和transactionFactory构建environment注册到configuration
5.解析typeHandlers,注册typeHandlerRegistry.register(typeHandlerClass);
6.解析mappers,根据类型解析xml或者直接addMapper
SqlSessionFactory
提供OpenSession方法,获取SqlSession
SqlSession
提供查询、更新、插入、删除接口,从configuration获取MapperStatement,然后底层委托给Executor实现
提供获取Mapper接口,底层委托给Configuration的getMapper
Executor

1.BaseExecutor:实现一级缓存,与statement交互逻辑交给子类实现
2.SimpleExecutor:每次执行sql,创建一个statement,用完关闭,默认配置
3.BatchExecutor:批量执行update语句,执行select语句时先flushStatements
4.ReuseExecutor:复用statement,如果sql相同从map中获取statement,flushStatements时关闭所有statement
5.cachingExecutor:使用装饰者模式,实现二级缓存
executor将statement与db交互的逻辑委托给StatementHandler
StatementHandler

1.SimpleStatementHandler:实现Statement与db交互功能,相当于下面的语句
Statement stm = conn.createStatement()
return stm.execute(sql);
2.PreparedStatementHandler:实现PreparedStatement与db交互功能,相当于下面的语句
PreparedStatement pstm = conn.prepareStatement(sql);
pstm.setString(1, "Hello");
return pstm.execute();
3.CallableStatementHandler:实现CallableStatement与db交互功能,相当于下面的语句
CallableStatement cs = conn.prepareCall("{call pr_add(?,?,?)}");
cs.registerOutParameter(3, Types.INTEGER);
cs.setInt(1, 10);
cs.setString(2, "Hello");
cs.execute();
return cs.getInt(3);
4.RoutingStatementHandler:根据MappedStatement的statementType将功能委托给上面三种statementHandler
ParameterHandler
setParameters:实现参数注入到preparedStatement中,相对与下面语句
preparedStatement.setString(1, "Hello");
preparedStatement.setString(2, "Hello");
preparedStatement.setString(3, "Hello");
callableStatement.setInt(1, 10);
callableStatement.setInt(2, 10);
callableStatement.setInt(3, 10);
ResultSetHandler
handlerResultSets:实现ResultSet结果转换为pojo,相当于下面的语句
User user = new User();
user.setId(resultSet.getInt("id"));
user.setName(resultSet.getString("name"));
TypeHandler
实现Statement参数设置和ResultSet类型转换
setParameter:ps.setArray(i, (Array) parameter);
getResult:rs.getArray(columnName)
整体sql流程

Mybatis核心模块简介的更多相关文章
- SSH与ansible 部署方法与核心模块简介
SSH与ansible 部署方法 部署环境 管理服务器 172.16.1.61 NFS服务器 172.16.1.31 备份服务器 172.16.1.41 1检查SSH服务是否运行并开启服务 netst ...
- Nodejs进阶:核心模块net入门与实例讲解
模块概览 net模块是同样是nodejs的核心模块.在http模块概览里提到,http.Server继承了net.Server,此外,http客户端与http服务端的通信均依赖于socket(net. ...
- Qt5模块简介
原文链接:Qt5 模块简介 无意中看到这篇文章,虽然讲的不是经常用的东西,但是看了这篇文章之后,可以对qt有个大致的了解,能够清晰的知道自己想要什么,应该关注那一部分,学习了,相信以后会又很大 ...
- MyBatis学习总结(二)——MyBatis核心配置文件与输入输出映射
在上一章中我们学习了<MyBatis学习总结(一)——ORM概要与MyBatis快速起步>,这一章主要是介绍MyBatis核心配置文件.使用接口+XML实现完整数据访问.输入参数映射与输出 ...
- [转]ASP.NET 核心模块配置参考
本文转自:https://docs.microsoft.com/zh-cn/aspnet/core/host-and-deploy/aspnet-core-module?view=aspnetcore ...
- 1.2(Mybatis学习笔记)Mybatis核心配置
一.Mybatis核心对象 1.1SqlSeesionFactory SqlSessionFactory主要作用是创建时SqlSession. SqlSessionFactory可通过SqlSessi ...
- Qt 学习之路 2(6):Qt 模块简介
Home / Qt 学习之路 2 / Qt 学习之路 2(6):Qt 模块简介 豆子 2012年8月26日 Qt 学习之路 2 20条评论 Qt 5 与 Qt 4 最大的一个区别之一是底层架构 ...
- MyBatis 核心配置综述之 ParameterHandler
目录 ParameterHandler 简介 ParameterHandler 创建 ParameterHandler 中的参数从何而来 ParameterHandler 解析 MyBatis 四大核 ...
- iOS开发UI篇—核心动画简介
转自:http://www.cnblogs.com/wendingding/p/3801036.html iOS开发UI篇—核心动画简介 一.简单介绍 Core Animation,中文翻译为核心动画 ...
随机推荐
- python的一些基础知识
一.函数介绍 二.模块与包 三.面向对象介绍 四.网络编程基础应用了解 五.基于MySQL对数据库的理解及基础操作 六.粗浅学习的前端知识整理
- 个人项目-Wc-Java
一.Github项目地址: https://github.com/Heiofungfming/xiaoming01 二.PSP表格 PSP2.1 任务内容 计划完成需要的时间(min) 实际完成需要的 ...
- 入门大数据---Kylin搭建与应用
由于Kylin官网已经是中文的了,而且写的很详细,这里就不再重述. 学习右转即可. 这里说个遇到的问题,当在Kylin使用SQL关键字时,要加上双引号,并且里面的内容要大写,这个和MySql有点区别需 ...
- C++ Primer Plus(四)
完整阅读C++ Primer Plus 系统重新学习C++语言部分,记录重要但易被忽略的,关键但易被遗忘的. 友元.异常和其他 1.抛出异常类时,虽然catch的是一个引用,但是也会产生一次拷贝,因为 ...
- IntelliJ IDEA安装配置、搭建Spring MVC
安装前必备软件: 1.jdk1.8.0_144安装包 2.IntelliJ IDEA 2016.1.1(64) 3.Tomcat安装包 4.Mysql.MySQL-JDBC驱动安装包 5.Jetbra ...
- python在循环中追加字典
1. 在循环中用append增加key值,最终生成全是key值的list: 2. 在循环中用append增加value值,最终生成全是value值的list: 3. 最后用zip将两个list合并成一 ...
- Python实用笔记 (8)高级特性——迭代
如果给定一个list或tuple,我们可以通过for循环来遍历这个list或tuple,这种遍历我们称为迭代(Iteration). 比如dict就可以迭代: >>> d = {'a ...
- 如何在项目开发中应用好“Deadline 是第一生产力”?
我想也许你早就听说过"Deadline是第一生产力"这句话,哪怕以前没听说过,我相信看完本文后,再也不会忘记这句话,甚至时不时还要感慨一句:"Deadline是第一生产力 ...
- 用JQuery解析获取JSON数据
JSON 是一种比较方便的数据形式,下面使用$.getJSON方法,实现获得JSON数据和解析,都挺方便简单的.从http://api.flickr.com/services/feeds/photos ...
- FTP学习
FTP服务的使用 一.LVM理论 介绍 FTP用于在Internet 上控制文件的双向传输. FTP的主要作用就是让用户连接一 个远程计算机(这些计算机上 运行着FTP服务器程序) ,并查看远程计算机 ...