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
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Java 字符串转float运算 float转字符串的方法
Android实现简单MD5加密的方法
基于java构造方法Vector创建对象源码分析
![](https://img.aspxhome.com/file/2023/3/60043_0s.png)
SpringBoot向容器注册bean的方法详解
![](https://img.aspxhome.com/file/2023/5/91545_0s.jpg)
c#重写TabControl控件实现关闭按钮的方法
![](https://img.aspxhome.com/file/2023/6/108626_0s.png)
SpringBoot 整合 ElasticSearch操作各种高级查询搜索
使用JAVA实现http通信详解
![](https://img.aspxhome.com/file/2023/4/61924_0s.png)
JDBC核心技术详解
![](https://img.aspxhome.com/file/2023/9/63169_0s.png)
android实现状态栏添加图标的函数实例
Java动态线程池插件dynamic-tp集成zookeeper
Java 实战项目之CRM客户管理系统的实现流程
![](https://img.aspxhome.com/file/2023/9/125249_0s.png)
C#实现简单的计算器功能
![](https://img.aspxhome.com/file/2023/8/70408_0s.jpg)
详解spring注解式参数校验
Android框架Volley之利用Imageloader和NetWorkImageView加载图片的方法
![](https://img.aspxhome.com/file/2023/1/137371_0s.jpg)
C#实现快捷键的几种常用方法汇总
Intellij IDEA 阅读源码的 4 个绝技(必看)
![](https://img.aspxhome.com/file/2023/9/106109_0s.png)
java数据结构与算法数组模拟队列示例详解
![](https://img.aspxhome.com/file/2023/0/80980_0s.png)
Android Studio多工程引用同一个library项目配置的解决方法
![](https://img.aspxhome.com/file/2023/2/138972_0s.png)
MyBatis中的JdbcType映射使用详解
![](https://img.aspxhome.com/file/2023/5/58275_0s.jpg)
java根据不同的参数调用不同的实现类操作
![](https://img.aspxhome.com/file/2023/4/83064_0s.jpg)