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 Swing实现自助取款机系统
Jun 11 Java/Android
在Java中Collection的一些常用方法总结
Jun 13 Java/Android
SpringBoot集成Redis,并自定义对象序列化操作
Jun 22 Java/Android
SpringBoot整合JWT的入门指南
Jun 29 Java/Android
java设计模式--建造者模式详解
Jul 21 Java/Android
SpringBoot整合Mybatis Generator自动生成代码
Aug 23 Java/Android
深入浅出讲解Java8函数式编程
Jan 18 Java/Android
java executor包参数处理功能 
Feb 15 Java/Android
Java的Object类的九种方法
Apr 13 Java/Android
SpringBoot使用ip2region获取地理位置信息的方法
Jun 21 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
PHP中的魔术方法总结和使用实例
2015/05/11 PHP
微信封装的调用微信签名包的类库
2017/06/08 PHP
使用PHPExcel实现数据批量导出为excel表格的方法(必看)
2017/06/09 PHP
Avengerls vs Newbee BO3 第三场2.18
2021/03/10 DOTA
jquery.validate使用攻略 第二部
2010/07/01 Javascript
JS实现标签页效果(配合css)
2013/04/03 Javascript
JavaScript的strict模式与with关键字介绍
2014/02/08 Javascript
4种JavaScript实现简单tab选项卡切换的方法
2016/01/06 Javascript
KnockoutJS 3.X API 第四章之数据控制流with绑定
2016/10/10 Javascript
Angularjs 设置全局变量的方法总结
2016/10/20 Javascript
css配合JavaScript实现tab标签切换效果
2018/10/11 Javascript
移动端图片上传旋转、压缩问题的方法
2018/10/16 Javascript
浅谈Layui的eleTree树式选择器使用方法
2019/09/25 Javascript
python调用windows api锁定计算机示例
2014/04/17 Python
八大排序算法的Python实现
2021/01/28 Python
python dataframe常见操作方法:实现取行、列、切片、统计特征值
2018/06/09 Python
使用Python来开发微信功能
2018/06/13 Python
python3使用pandas获取股票数据的方法
2018/12/22 Python
python tkinter库实现气泡屏保和锁屏
2019/07/29 Python
Python sep参数使用方法详解
2020/02/12 Python
PyQt5的相对布局管理的实现
2020/08/07 Python
Python‘==‘ 及 ‘is‘相关原理解析
2020/09/05 Python
Pycharm Available Package无法显示/安装包的问题Error Loading Package List解决
2020/09/18 Python
如何用Python编写一个电子考勤系统
2021/02/08 Python
常用的HTML5列表标签
2017/06/20 HTML / CSS
教师通用专业自荐书范文
2014/02/11 职场文书
小学综合实践活动总结
2014/07/07 职场文书
党员干部观看《周恩来四个昼夜》思想汇报
2014/09/10 职场文书
2014教师党员个人自我评议
2014/09/20 职场文书
居委会个人对照检查材料思想汇报
2014/09/29 职场文书
2014年人事行政工作总结
2014/12/03 职场文书
给老师的感谢信
2015/01/20 职场文书
医院岗前培训心得体会
2016/01/08 职场文书
CSS3点击按钮圆形进度打钩效果的实现代码
2021/03/30 HTML / CSS
如何优化vue打包文件过大
2022/04/13 Vue.js
winserver2019安装软件一直卡在应用程序正在为首次使用做准备
2022/06/10 Servers