mybatis源码解读之executor包语句处理功能


Posted in Java/Android onFebruary 15, 2022

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、preparedStatementCallableStatement对象。通过其中的parameterize方法可以看出三个Statement处理器的不同。

SimpleStatementHandlerparameterize方法的实现为空,因为它只需要完成字符串替换即可,不需要进行参数处理

public class SimpleStatementHandler extends BaseStatementHandler {

 @Override
  public void parameterize(Statement statement) {
    // N/A
  }

  }

PreparedStatementHandlerparameterize方法最终通过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);
  }

}

到此这篇关于  mybatis源码解读之executor包语句处理功能的文章就介绍到这了,更多相关executor包语句处理内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Java/Android 相关文章推荐
Java输出Hello World完美过程解析
Jun 13 Java/Android
Java用自带的Image IO给图片添加水印
Jun 15 Java/Android
分析设计模式之模板方法Java实现
Jun 23 Java/Android
使用Spring处理x-www-form-urlencoded方式
Nov 02 Java/Android
springboot 多数据源配置不生效遇到的坑及解决
Nov 17 Java/Android
Spring this调用当前类方法无法拦截的示例代码
Mar 20 Java/Android
Java 超详细讲解十大排序算法面试无忧
Apr 08 Java/Android
Java死锁的排查
May 11 Java/Android
Java 死锁解决方案
May 11 Java/Android
SpringBoot全局异常处理方案分享
May 25 Java/Android
SpringBoot项目部署到阿里云服务器的实现步骤
Jun 28 Java/Android
Java使用HttpClient实现文件下载
Aug 14 Java/Android
java executor包参数处理功能 
Feb 15 #Java/Android
Java如何实现通过键盘输入一个数组
Feb 15 #Java/Android
Java实现给Word文件添加文字水印
Feb 15 #Java/Android
SSM项目使用拦截器实现登录验证功能
Jan 22 #Java/Android
利用Sharding-Jdbc进行分库分表的操作代码
关于MybatisPlus配置双数据库驱动连接数据库问题
Jan 22 #Java/Android
JavaCV实现照片马赛克效果
Jan 22 #Java/Android
You might like
建立动态的WML站点(二)
2006/10/09 PHP
php 生成文字png图片的代码
2011/04/17 PHP
Yii2中Restful API原理实例分析
2016/07/25 PHP
JavaScript的漂亮的代码片段
2013/06/05 Javascript
Eclipse下jQuery文件报错出现错误提示红叉
2014/01/13 Javascript
Node.js 制作实时多人游戏框架
2015/01/08 Javascript
如何利用AngularJS打造一款简单Web应用
2015/12/05 Javascript
Bootstrap每天必学之导航条(二)
2016/03/01 Javascript
JS实现n秒后自动跳转的两种方法
2020/11/30 Javascript
Bootstrap导航条可点击和鼠标悬停显示下拉菜单
2016/11/25 Javascript
bootstrap学习使用(导航条、下拉菜单、轮播、栅格布局等)
2016/12/01 Javascript
JavaScript ES6中const、let与var的对比详解
2017/06/18 Javascript
详解Vue整合axios的实例代码
2017/06/21 Javascript
原生JS实现随机点名项目的实例代码
2019/04/30 Javascript
vue实现简单的日历效果
2020/09/24 Javascript
vue使用自定义指令实现拖拽
2021/01/29 Javascript
解决在layer.open中使用时间控件laydate失败的问题
2019/09/11 Javascript
JavaScript this在函数中的指向及实例详解
2019/10/14 Javascript
Vue 3.0 全家桶抢先体验
2020/04/28 Javascript
[46:32]Fnatic vs OG 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python实现Linux下守护进程的编写方法
2014/08/22 Python
python使用urllib2实现发送带cookie的请求
2015/04/28 Python
Python实现类的创建与使用方法示例
2017/07/25 Python
浅谈Pandas中map, applymap and apply的区别
2018/04/10 Python
Python3.5运算符操作实例详解
2019/04/25 Python
如何更换python默认编辑器的背景色
2020/08/10 Python
松下电器美国官方商店:Panasonic美国
2016/10/14 全球购物
美国庭院家具购物网站:AlphaMarts
2019/04/10 全球购物
Jar包的作用是什么
2014/03/30 面试题
酒店中秋节促销方案
2014/01/30 职场文书
优秀信贷员先进事迹
2014/01/31 职场文书
产品开发计划书
2014/04/27 职场文书
寻找最美家庭活动方案
2014/08/20 职场文书
机关作风建设剖析材料
2014/10/11 职场文书
求职信内容一般写什么?
2015/03/20 职场文书
Pyhton爬虫知识之正则表达式详解
2022/04/01 Python