mybatis源码解读-Java中executor包的语句处理功能
作者:灰太狼_cxh 发布时间:2023-09-03 06:34:16
1.mybatis对多语句类型的支持
在mybatis映射文件中传参数,主要用到#{}
或者 ${}
.
#{}:表示使用这种符号的变量会以预编译的形式赋值到sql片段中。
${}:表示使用这种符号的变量会以字符串的形式直接插到sql片段中。
mybatis中支持三种语句类型,不同语句类型支持的变量符号不同。mybatis的三种类型如下:
STATEMENT:这种语句类型中,只会对sql片段进行简单的字符串拼接。只支持使用${}.
PREPARED:这种语句中会先对sql片段进行字符串拼接,然后再对sql片段进行赋值。可以使用#{}和${}.
CALLABLE:这种语句用了实现执行过程的调用,会先对sql片段进行字符串拼接,然后对sql片段进行赋值。可以使用#{}和${}.
2.mybatis的语句处理功能
statement
子包负责提供语句处理功能,其中StatementHandler
是语句功能类的父接口,RoutingStatementHandler类是一个代理类,它能够根据传入的MappedStatement对象的具体类型选中一个具体的被代理对象,然后将所有实际操作都委托给被代理对象。所以RoutingStatementHandler
类提供的是路由功能,而路由选择的依据就是语句类型。
public class RoutingStatementHandler implements StatementHandler {
// 根据语句类型选取出的被代理类的对象
private final StatementHandler delegate;
public RoutingStatementHandler(Executor executor, MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, BoundSql boundSql) {
// 根据语句类型选择被代理对象
switch (ms.getStatementType()) {
case STATEMENT:
delegate = new SimpleStatementHandler(executor, ms, parameter, rowBounds, resultHandler, boundSql);
break;
case PREPARED:
delegate = new PreparedStatementHandler(executor, ms, parameter, rowBounds, resultHandler, boundSql);
break;
case CALLABLE:
delegate = new CallableStatementHandler(executor, ms, parameter, rowBounds, resultHandler, boundSql);
break;
default:
throw new ExecutorException("Unknown statement type: " + ms.getStatementType());
}
}
}
BaseStatementHandler
作为三个实现类的父类,提供了实现类的公共方法。并且BaseStatementHandler
类使用的模板模式在prepare方法中定义了整个方法的框架,然后将一些与子类相关的操作交给三个子类处理。
SimpleStatementHandler
类、PreparedStatementHandler
类和CallableStatementHandler
类是三个真正的statement处理器,分别处理statement、preparedStatement、CallableStatement对象。通过其中的parameterize方法可以看出三个Statement处理器的不同。
SimpleStatementHandler中parameterize方法的实现为空,因为它只需要完成字符串替换即可,不需要进行参数处理
public class SimpleStatementHandler extends BaseStatementHandler {
@Override
public void parameterize(Statement statement) {
// N/A
}
}
PreparedStatementHandler
中parameterize
方法最终通过ParameterHandler接口经过多级中转后调用了PreparedStatement类中的参数赋值方法。
public class PreparedStatementHandler extends BaseStatementHandler {
@Override
public void parameterize(Statement statement) throws SQLException {
parameterHandler.setParameters((PreparedStatement) statement);
}
}
CallableStatementHandler
中parameterize
主要是通过registerOutputParameters方法中转后调用CallableStatement中的输出参数注册方法完成输出参数的注册,然后通过ParameterHandler接口经过多级中转后调用了PreparedStatement类中的参数赋值方法。
public class CallableStatementHandler extends BaseStatementHandler {
/**
* 对语句进行参数处理
* @param statement SQL语句
* @throws SQLException
*/
@Override
public void parameterize(Statement statement) throws SQLException {
// 输出参数的注册
registerOutputParameters((CallableStatement) statement);
// 输入参数的处理
parameterHandler.setParameters((CallableStatement) statement);
}
}
来源:https://blog.51cto.com/u_13321676/5006105


猜你喜欢
- 一、概述System.Net.WebClient属于高层类、使用简单。均支持异步版本。支持http,https,fpt,files等URI。
- 从功能上说,可以分为两部分,分布式功能和数据功能。分布式功能主要是节点集群及集群附属功能如restful借口、集群性能检测功能等,数据功能主
- 今天我们介绍的是jpa删除和事务的一些坑,接下来看看具体内容。业务场景(这是一个在线考试系统)和代码:根据问题的id删除答案reposito
- 引言HDFS Balancer工具可以用来分析块的分布情况,并且可以重新分配DataNode中的数据。本文通过为您介绍如何使用HDFS Ba
- 1.把springboot项目打包成三个jar包,并指定端口为14341,14342,143432.下载腾讯云免费ssl证书,解压后会出现如
- 在客户机和服务器之间建立单一的双向连接,这就意味着客户只需要发送一个请求到服务端,那么服务端则会进行处理,处理好后则将其返回给客户端,客户端
- java在jdk1.5中引入了注解,spring框架也正好把java注解发挥得淋漓尽致。下面会讲解Spring中自定义注解的简单流程,其中会
- 1.spring boot * 默认有:HandlerInterceptorAdapterAbstractHandlerMappingUse
- 如果说C#和C++有什么不同,博主不得不说,对于异步的支持程度是C#的一一个伟大的进步。
- 前言你好! 本文章主要介绍如何用Android Studio制作简易的门户界面,主要说明框架的各部分功能与实现过程,结尾处附有源码。界面分析
- 本文实例为大家分享了C#使用NPOI将excel导入到list的具体代码,供大家参考,具体内容如下这个是确定是实体类接收/// <su
- 为什么我们需要IntentService ?Android中的IntentService是继承自Service类的,在我们讨论IntentS
- EntityWrapper使用解析1、项目中引入jar包,我这里使用Maven构建<dependency> &nbs
- 本文实例为大家分享了Unity实现3D循环滚动效果展示的具体代码,供大家参考,具体内容如下然后通过SetDepthAndPosition这个
- Handler是用于操作线程内部的消息队列的类。这有点绕,没关系,我们慢慢的来讲。前面Looper一篇讲到了Looper是用于给线程创建消息
- 前言:小编引入的图片和文字描述都是来自于尚硅谷的视频讲解,在此感谢尚硅谷的老师,同时也结合 seata文档官方文档进行整合项目地址(gite
- @SpringBootTest加速单元测试小诀窍PreSpringBoot - 应用程序测试方案随着代码量的争夺,测试类的启动速度变得越来越
- 在使用Gateway 调用一个文件上传服务时 前端传来的File的base64字符串怎么都接受不到 但是用Body方式请求就能接收到后来经过
- 程序分析: 兔子的规律为数列1,1,2,3,5,8,13,21....程序设计:public class exp2{ publi
- 界面效果图如下:报表界面说下关键代码 需要开启 Windows Management Instrumentation服务(默认已经