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 相关文章推荐
Springboot如何使用logback实现多环境配置?
Jun 16 Java/Android
详解Java实践之适配器模式
Jun 18 Java/Android
springboot如何初始化执行sql语句
Jun 22 Java/Android
Springboot集成阿里云OSS上传文件系统教程
Jun 28 Java/Android
利用Java设置Word文本框中的文字旋转方向的实现方法
Jun 28 Java/Android
Java并发编程之原子性-Atomic的使用
Mar 16 Java/Android
Java 超详细讲解ThreadLocal类的使用
Apr 07 Java/Android
Java 数组的使用
May 11 Java/Android
Android Canvas绘制文字横纵向对齐
Jun 05 Java/Android
Spring JPA 增加字段执行异常问题及解决
Jun 10 Java/Android
httpclient调用远程接口的方法
Aug 14 Java/Android
Spring boot实现上传文件到本地服务器
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
在Zeus Web Server中安装PHP语言支持
2006/10/09 PHP
PHP中使用CURL伪造来路抓取页面或文件
2011/05/04 PHP
php中使用接口实现工厂设计模式的代码
2012/06/17 PHP
在html文件中也可以执行php语句的方法
2015/04/09 PHP
Android AsyncTack 异步任务实例详解
2016/11/02 PHP
php把时间戳转换成多少时间之前函数的实例
2016/11/16 PHP
php正则提取html图片(img)src地址与任意属性的方法
2017/02/08 PHP
php实现JWT验证的实例教程
2020/11/26 PHP
javascript对象的property和prototype是这样一种关系
2007/03/24 Javascript
解析Javascript小括号“()”的多义性
2013/12/03 Javascript
AngularJS入门心得之directive和controller通信过程
2016/01/25 Javascript
移动端界面的适配
2017/01/11 Javascript
jQuery Validate 相关参数及常用的自定义验证规则
2017/03/06 Javascript
Angular.js基础学习之初始化
2017/03/10 Javascript
JS实现经典的中国地区三级联动下拉菜单功能实例【测试可用】
2017/06/06 Javascript
Vue.js组件通信的几种姿势
2017/10/23 Javascript
vue+element-ui动态生成多级表头的方法
2018/08/28 Javascript
js核心基础之构造函数constructor用法实例分析
2019/05/11 Javascript
jQuery实现的上拉刷新功能组件示例
2020/05/01 jQuery
Vue.js中使用Vuex实现组件数据共享案例
2020/07/31 Javascript
node.js如何操作MySQL数据库
2020/10/29 Javascript
[02:34]DOTA2亚洲邀请赛 BG战队出场宣传片
2015/03/09 DOTA
Python将xml和xsl转换为html的方法
2015/03/10 Python
python实现根据ip地址反向查找主机名称的方法
2015/04/29 Python
Python实现复杂对象转JSON的方法示例
2017/06/22 Python
Python Flask 搭建微信小程序后台详解
2019/05/06 Python
pandas to_excel 添加颜色操作
2020/07/14 Python
幼儿园实习自我鉴定
2013/12/15 职场文书
饲料采购员岗位职责
2013/12/19 职场文书
医院总经理职责
2013/12/26 职场文书
新教师工作感言
2014/02/16 职场文书
大学生自我评价范文分享
2014/02/21 职场文书
孝敬父母的演讲稿
2014/05/14 职场文书
2014小学教师年度考核工作总结
2014/12/03 职场文书
numpy数据类型dtype转换实现
2021/04/24 Python
零基础学java之方法的定义与调用详解
2022/04/10 Java/Android