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 相关文章推荐
springcloud之Feign超时问题的解决
Jun 24 Java/Android
Netty结合Protobuf进行编解码的方法
Jun 26 Java/Android
详解Java线程池是如何重复利用空闲线程的
Jun 26 Java/Android
使用Springboot实现健身房管理系统
Jul 01 Java/Android
SpringBoot集成Druid连接池连接MySQL8.0.11
Jul 02 Java/Android
SpringRetry重试框架的具体使用
Jul 25 Java/Android
Java并发编程之原子性-Atomic的使用
Mar 16 Java/Android
Spring事务管理下synchronized锁失效问题的解决方法
Mar 31 Java/Android
Android超详细讲解组件ScrollView的使用
Mar 31 Java/Android
SpringCloud项目如何解决log4j2漏洞
Apr 10 Java/Android
Java完整实现记事本代码
Jun 16 Java/Android
利用Java连接Hadoop进行编程
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
JavaScript是否可实现多线程  深入理解JavaScript定时机制
2009/12/22 Javascript
JQuery 动画卷页 返回顶部 动画特效(兼容Chrome)
2010/02/15 Javascript
jquery进行数组遍历如何跳出当前的each循环
2014/06/05 Javascript
js打造数组转json函数
2015/01/14 Javascript
一种新的javascript对象创建方式Object.create()
2015/12/28 Javascript
laypage分页控件使用实例详解
2016/05/19 Javascript
javascript将中国数字格式转换成欧式数字格式的简单实例
2016/08/02 Javascript
jquery easyUI中ajax异步校验用户名
2016/08/19 Javascript
基于jQuery实现手风琴菜单、层级菜单、置顶菜单、无缝滚动效果
2017/07/20 jQuery
微信小程序 五星评分的实现实例
2017/08/04 Javascript
ES7中利用Await减少回调嵌套的方法详解
2017/11/01 Javascript
详解PHP后期静态绑定分析与应用
2018/03/21 Javascript
js生成1到100的随机数最简单的实现方法
2020/02/07 Javascript
对vue生命周期的深入理解
2020/12/03 Vue.js
python使用心得之获得github代码库列表
2014/06/25 Python
python实现将pvr格式转换成pvr.ccz的方法
2015/04/28 Python
Python如何快速上手? 快速掌握一门新语言的方法
2017/11/14 Python
python实现梯度下降算法
2020/03/24 Python
Python实现制度转换(货币,温度,长度)
2019/07/14 Python
浅谈Django中view对数据库的调用方法
2019/07/18 Python
python并发编程 Process对象的其他属性方法join方法详解
2019/08/20 Python
Python的Django框架实现数据库查询(不返回QuerySet的方法)
2020/05/19 Python
python palywright库基本使用
2021/01/21 Python
css3制作彩色边线3d立体按钮的示例(css3按钮)
2014/05/06 HTML / CSS
css3实现多个元素依次显示效果
2017/12/12 HTML / CSS
求职简历自荐信范文
2013/10/21 职场文书
2014年高中生自我评价范文
2014/09/26 职场文书
班主任2015新年寄语
2014/12/08 职场文书
优秀教师单行材料
2014/12/16 职场文书
教师个人考察材料
2014/12/16 职场文书
《平行四边形的面积》教学反思
2016/02/16 职场文书
jquery插件实现图片悬浮
2021/04/16 jQuery
Python字符串对齐方法使用(ljust()、rjust()和center())
2021/04/26 Python
MySQL中你可能忽略的COLLATION实例详解
2021/05/12 MySQL
详解redis在微服务领域的贡献
2021/10/16 Redis
Win10系统搭建ftp文件服务器详细教程
2022/08/05 Servers