mybatis源码解读之executor包语句处理功能
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、preparedStatement
、CallableStatement
对象。通过其中的parameterize
方法可以看出三个Statement
处理器的不同。
SimpleStatementHandler
中parameterize
方法的实现为空,因为它只需要完成字符串替换即可,不需要进行参数处理
public class SimpleStatementHandler extends BaseStatementHandler { @Override public void parameterize(Statement statement) { // N/A } }
PreparedStatementHandler
中parameterize
方法最终通过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包语句处理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
SpringBoot配置SSL同时支持http和https访问实现
本文主要介绍了SpringBoot配置SSL同时支持http和https访问实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-07-07SpringCloud zookeeper作为注册中心使用介绍
ZooKeeper由雅虎研究院开发,是Google Chubby的开源实现,后来托管到Apache,于2010年11月正式成为Apache的顶级项目。ZooKeeper是一个经典的分布式数据一致性解决方案,致力于为分布式应用提供一个高性能、高可用,且具有严格顺序访问控制能力的分布式协调服务2022-11-11最新IntelliJ IDEA 2021版配置 Tomcat 8.5 的详细步骤
idea开发工具一直是java环境最好用,很受广大开发者喜爱,今天通过本文给大家分享最新IntelliJ IDEA 2021版配置 Tomcat 8.5 的详细步骤,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下2021-06-06
最新评论