mybatis源码解读-Java中executor包的语句处理功能
目录
- 1.mybatis对多语句类型的支持
- 2.mybatis的语句处理功能
1.mybatis对多语句类型的支持 在mybatis映射文件中传参数,主要用到
#{}
或者 ${}
.- #{}:表示使用这种符号的变量会以预编译的形式赋值到sql片段中。
- ${}:表示使用这种符号的变量会以字符串的形式直接插到sql片段中。
- 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 { @Overridepublic void parameterize(Statement statement) {// N/A}}
PreparedStatementHandler
中parameterize
方法最终通过ParameterHandler接口经过多级中转后调用了PreparedStatement类中的参数赋值方法。public class PreparedStatementHandler extends BaseStatementHandler {@Overridepublic 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*/@Overridepublic void parameterize(Statement statement) throws SQLException {// 输出参数的注册registerOutputParameters((CallableStatement) statement); // 输入参数的处理parameterHandler.setParameters((CallableStatement) statement); }}
【mybatis源码解读-Java中executor包的语句处理功能】到此这篇关于mybatis源码解读-Java中executor包的语句处理功能的文章就介绍到这了,更多相关executor包语句处理功能内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
推荐阅读
- MyBatis使用resultMap如何解决列名和属性名不一致
- 一比一还原axios源码(一)——|一比一还原axios源码(一)—— 发起第一个请求
- 聊聊 Pulsar(编译 Pulsar 源码并搭建源码环境)
- 详细解读阿里云数据库开源PolarDB总体架构和企业级特性
- MyBatis如何使用selectKey返回主键的值
- MyBatis中一对多的xml配置方式(嵌套查询/嵌套结果)
- Java|Java 精炼解读递归的概念与使用
- HTML|马上跨年了,室友靠我的十款不同表白代码顺利脱单【内附源码】
- 音视频开发|FFmpeg源码分析(avcodec_open()打开编解码器)
- cnn|“看得见的”卷积神经网络(图文并茂+代码解读)(卷积神经网络可视化)