接上篇手写持久层框架:https://blog.csdn.net/liwenyang1992/article/details/134884703
MyBatis架构四层作用是什么呢?
API接口层:提供API,增加、删除、修改、查询等接口,通过API接口对数据库进行操作。
数据处理层:主要负责SQL的 查询、解析、执行以及结果映射的处理,主要作用解析SQL根据调用请求完成一次数据库操作。
框架支撑层:负责通用基础服务支撑,包含事务管理、连接池管理、缓存管理等共用组件的封装,为上层提供基础服务支撑。
包路径org.apache.ibatis
包路径 | 作用备注 |
---|---|
annotations | Mapper映射器接口中使用到的注解 |
binding | Mapper映射器接口与映射语句关系绑定构建 |
builder | Configuration配置的构建包 |
cache | 缓存实现与定义(包含一级/二级缓存) |
cursor | 游标(针对查询结果集的获取与遍历等) |
datasource | 数据源/连接池 |
exceptions | 异常包 |
executor | 语句执行器(包含参数/结果集/语句处理等) |
io | 资源读取辅助包 |
jdbc | MyBatis内部的SQL脚本运行的测试包 |
logging | 一套日志接口和适配器包 |
mapping | Mapper映射器相关参数/语句/结果/类型等对象包 |
parsing | XML解析包(例如#{}占位符解析) |
plugin | 插件包 |
reflection | 反射处理工具包 |
scripting | SQL执行脚本的解析处理包 |
session | 数据库连接会话核心包(会话创建/管理/调用) |
transaction | 事务 |
type | 类型处理器(定义bean与数据库类型的转换关系) |
MyBatis的真正强大在于它的语句映射,这是它的魔力所在,由于它的异常强大,映射器的XML文件就显得相对简单。如果拿它跟具有相同功能的JDBC代码进行对比,你会立即发现省掉了将近95% 的代码。MyBatis致力于减少使用成本,让用户能更专注于 SQL 代码。
SQL 映射文件只有很少的几个顶级元素(按照应被定义的顺序列出):
select元素允许你配置很多属性来配置每条语句的行为细节
<select
id="select"
parameterType="int"
resultType="resultType"
resultMap="resultMap"
flushCache="false"
useCache="true"
timeout="10"
fetchSize="256"
statementType="PREPARED"
resultSetType="FORWARD_ONLY"></select>
数据变更语句insert, update 和 delete 的实现非常接近
借助功能强大的基于OGNL的表达式,MyBatis 3 替换了之前的大部分元素,大大精简了元素种类
<select id="findActiveBlogLike"
resultType="Blog">
SELECT * FROM BLOG WHERE state = ‘ACTIVE’
<choose>
<when test="title != null">
AND title like #{title}
</when>
<when test="author != null and author.name != null">
AND author_name like #{author.name}
</when>
<otherwise>
AND featured = 1
</otherwise>
</choose>
</select>
XMLScriptBuilder
public SqlSource parseScriptNode()方法:
SqlSession接口的默认实现类
Executor接口:
BaseExecutor:基础执行器,封装了子类的公共方法及公共变量,包括一级缓存、延迟加载、回滚、关闭等功能;
SimpleExecutor:简单执行器,每执行一条SQL,都会打开一个 Statement,执行完成后关闭;
ReuseExecutor:重用执行器,相较于 SimpleExecutor多了 Statement 的缓存功能,其内部维护一个Map<String, Statement>
,每次编译完成的Statement 都会进行缓存,不会关闭;
BatchExecutor:批量执行器,基于JDBC的addBatch、executeBatch
功能,并且在当前SQL和上一条SQL完全一样的时候,重用Statement,在调用doFlushStatements
的时候,将数据刷新到数据库;
CachingExecutor:缓存执行器,装饰器模式,在开启缓存的时候。会在上面三种执行器的外面包上 CachingExecutor;
BaseStatementHandler
抽象类,对应 java.sql.Statement 对象的外理,处理普通的不带动态参数运行的SQL,即执行简单拼接的字符串语句,同时由于 Statement 的特性,SimpleStatementHandler 每次执行都需要编译 SQL**(注意:我们知道 SQL 的执行是需要编译和解析的)。**BaseStatementHandler
抽象类,对应 java.sql.PrepareStatement 对象的处理,相比上面的普通语句处理器,它支持可变参数 SQL执行,由于 PrepareStatement 的特性,它会进行预编译,在缓存中一旦发现有预编译的命令,会直接解析执行,所以减少了再次编译环节,能够有效提高系统性能,并预防 SQL 注入攻击**(所以是系统默认也是我们推荐的语句处理器)**BaseStatementHandler
抽象类,对应 java.sql.CallableStatement 对象的处理,很明了,它是用来调用存储过程的,增加了存储过程的函数调用以及输出/输入参数的处理支持。附件中包含测试用例代码,可设置jdk17调试运行,带注解。