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,中文翻译为核心动画 ...
随机推荐
- Elasticsearch的query phase和fetch phase
对于一次query查询到数据返回到客户端,经历了两个过程 query phase和fetch phase的过程 query phase 查询阶段 fetch phase 获取阶段. 1 qu ...
- 10、一个action中处理多个方法的调用第二种方法method的方式
在实际的项目中,经常采用现在的第二种方式在struct.xml中采用清单文件的方式 我们首先来看action package com.bjpowernode.struts2; import com.o ...
- JDK8--08:Optional
在程序运行时,空指针异常应该是最常见的异常之一,因此JDK8提供了Optional来避免空指针异常. 首先说明JDK8新增的Optional及相关方法的使用 Optional的常用操作: Option ...
- oracle如何实现自增?----用序列sequence的方法来实现
将表t_user的字段ID设置为自增:(用序列sequence的方法来实现) ----创建表 Create table t_user( Id number(6),userid varchar2(2 ...
- 使用TransferLearning实现环视图像的角点检测——yolo_v3_tiny
本文选取yolov3-tiny,使用pretrained weights,实现环视图像中的角点等关键目标检测. 大神镇楼: https://pjreddie.com/darknet/yolo/ 配置参 ...
- c语言学习笔记第四章——字符串和格式化输入、输出
B站有视频演示 本章学习printf函数的输入输出,字符串的定义与实用. 字符串 字符串(character string)是一个或多个字符的序列,如下所示: "Zing went the ...
- HBase2.0 meta信息丢失的修复方法
在HBase入库日志中发现有一个表入库失败,检查HBase服务端后发现该表的meta信息丢失了: 而HDFS上的region还在: 而HBCK工具不支持HBase2.0版本,只好自己写一个修复工具.网 ...
- tyvj 1198 矩阵连乘——区间dp
tyvj 1198 矩阵连乘 题目描述 一个n*m矩阵由n行m列共n*m个数排列而成.两个矩阵A和B可以相乘当且仅当A的列数等于B的行数.一个N*M的矩阵乘以一个M*P的矩阵等于一个N*P的矩阵,运算 ...
- Emergency Evacuation 题解
The Japanese government plans to increase the number of inbound tourists to forty million in the yea ...
- Vue动态修改class
#####对象方法-最简单的绑定(这里的active加不加单引号都可以,以下也一样都能渲染) :class="{ 'active': isActive }"1判断是否绑定一个act ...