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 Shutdown Hook场景使用及源码分析
Jun 15 Java/Android
SpringAop日志找不到方法的处理
Jun 21 Java/Android
java中重写父类方法加不加@Override详解
Jun 21 Java/Android
简单总结SpringMVC拦截器的使用方法
Jun 28 Java/Android
SpringBoot SpringEL表达式的使用
Jul 25 Java/Android
聊聊SpringBoot自动装配的魔力
Nov 17 Java/Android
解决persistence.xml配置文件修改存放路径的问题
Feb 24 Java/Android
Java详细解析==和equals的区别
Apr 07 Java/Android
Java 多线程协作作业之信号同步
May 11 Java/Android
JavaScript正则表达式实现注册信息校验功能
May 30 Java/Android
Java界面编程实现界面跳转
Jun 16 Java/Android
Java实现HTML转为Word的示例代码
Jun 28 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
PHP系统命令函数使用分析
2013/07/05 PHP
PHP实现中文圆形印章特效
2015/06/19 PHP
详解PHP多个进程配合redis的有序集合实现大文件去重
2019/03/06 PHP
xml和web特殊字符
2009/04/28 Javascript
基于MooTools的很有创意的滚动条时钟动画
2010/11/14 Javascript
js解析xml字符串和xml文档实现原理及代码(针对ie与火狐)
2013/02/02 Javascript
jquery仿京东导航/仿淘宝商城左侧分类导航下拉菜单效果
2013/04/24 Javascript
清除div下面的所有标签的方法
2014/02/17 Javascript
基于jquery实现select选择框内容左右移动添加删除代码分享
2015/08/25 Javascript
JavaScript程序设计之JS调试
2015/12/09 Javascript
简单了解Backbone.js的Model模型以及View视图的源码
2016/02/14 Javascript
JS生成和下载二维码的代码
2016/12/07 Javascript
Javascript中构造函数要注意的一些坑
2017/01/23 Javascript
vue 自定义提示框(Toast)组件的实现代码
2018/08/17 Javascript
深入理解Angularjs 脏值检测
2018/10/12 Javascript
深入理解 Koa 框架中间件原理
2018/10/18 Javascript
layui-table表复选框勾选的所有行数据获取的例子
2019/09/13 Javascript
Vue使用NProgress进度条的方法
2019/09/21 Javascript
[01:10:58]KG vs TNC 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
Python中用startswith()函数判断字符串开头的教程
2015/04/07 Python
Python 读写文件和file对象的方法(推荐)
2016/09/12 Python
浅谈django model postgres的json字段编码问题
2018/01/05 Python
Python自定义简单图轴简单实例
2018/01/08 Python
python列表的增删改查实例代码
2018/01/30 Python
PyQt5实现拖放功能
2018/04/25 Python
Win10下python 2.7.13 安装配置方法图文教程
2018/09/18 Python
使用python-opencv读取视频,计算视频总帧数及FPS的实现
2019/12/10 Python
django中ImageField的使用详解
2020/12/21 Python
举例详解CSS3中的Transition
2015/07/15 HTML / CSS
HTML5 window/iframe跨域传递消息 API介绍
2013/08/26 HTML / CSS
挂职学习心得体会
2014/09/09 职场文书
师德师风建设整改措施思想汇报
2014/10/11 职场文书
Django利用AJAX技术实现博文实时搜索
2021/05/06 Python
再也不用花钱买漫画!Python爬取某漫画的脚本及源码
2021/06/09 Python
深入理解CSS 中 transform matrix矩阵变换问题
2021/08/30 HTML / CSS
Python中的matplotlib绘制百分比堆叠柱状图,并为每一个类别设置不同的填充图案
2022/04/20 Python