在mybatis
映射文件中传参数,主要用到#{} 或者孟子主张什么思想 ${}.
#{}:表示使用这种符号的变量会以预编译的形式赋值到sql片段中。
${}:表示使用这种符号的变量会以字符串的形式直接插到sql片段中。
mybatis中支持三种语句类型,不同语句类型支持的变量符号不同。mybatis的三种类型如下:
statement
:这种语句类型中,只会对sql片段进行简单的字符串拼接。只支持使用${}.prepared
:这种语句中会先对sql片段进行字符串拼接,然后再对sql片段进行赋值。可以使用#{}和${}.callable
:这种语句用了并集和交集实现执行过程的调用,会先对sql片段进行字符串拼接,然后对sql片段进行赋值。可以使用#{}和${}.statement
子包负责提供语句处理功能,其中statementhandler
是语句功能类的父接口,routingstatementhand两字游戏idler
类是一个代理类,它能够根据传入的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()) { ca statement: delegate = new simplestatementhandler(executor, ms, parameter, rowbounds, resulthandler, boundsql); break; ca prepared: delegate = new preparedstatementhandler(executor, ms, parameter, rowbounds, resulthandler, boundsql); break; ca callable: delegate = new callablestatementhandler(executor, ms, parameter, rowbounds, resulthandler, boundsql); break; default: throw new executorexception("unknown statement type: " + ms.getstatementtype()); } }}
bastatementhandler
作为三个实现类的父类,提供了实现类的公共方法。并且bastatementhandler
类使用的模板模式在prepare
方法中定义了整个方法的框架,然后将一些与子类相关的操作交给三个子类处理。
simplestatementhandler
类、preparedstatementhandler
类和callablestatementhandler
类是三个真正的statement
处理器,分别处理statement、preparedstatement
、callablestatement
对象。通过其中的parameterize
方法可以看出三个statement
处理器的不同。
simplestatementhandler
中parameterize
方法的实现为空,因为它只需要完成字符串替换即可,不需要进行参数处理
public class simplestatementhandler extends bastatementhand有一种 叫做 作文ler {@override public void parameterize(statement statement) { // n/a } }
preparedstatementhandler
中parameterize
方法最终通过parameterhandler接口经过多级中转后调用了preparedstatement类中的参数赋值方法。
public class preparedstatementhandler extends bastatementhandler { @override public void parameterize(statement statement) throws sqlexception { parameterhandler.tparameters((preparedstatement) statement); }}
callablestatementhandler
中parameterize主要是通过registeroutputparameters方法中转后调用callablestatement中的输出参数注册方法完成输出参数的注册,然后通过parameterhandler接口经过多级中转后调用了preparedstatement类中的参数赋值方法。
public class callablestatementhandler extends bastatementhandler {/** * 对语句进行参数处理 * @param statement sql语句 * @throws sqlexception */ @override public void parameterize(statement statement) throws sqlexception { // 输出参数的注册 registeroutputparameters((callablestatement) statement); // 输入参数的处理 parameterhandler.tparameters((callablestatement) statement); }}
到此这篇关于 mybatis源码解读之executor包语句处理功能的文章就介绍到这了,更多相关executor包语句处理内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-05 01:13:18,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/0af86e0ad15744537fef7cb018c7aa54.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:mybatis源码解读之executor包语句处理功能.doc
本文 PDF 下载地址:mybatis源码解读之executor包语句处理功能.pdf
留言与评论(共有 0 条评论) |