mybatis的executor包语句处理功能源码分析
这篇“mybatis的executor包语句处理功能源码分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mybatis的executor包语句处理功能源码分析”文章吧。
1.mybatis对多语句类型的支持在mybatis
映射文件中传参数,主要用到#{} 或者 ${}.
#{}:表示使用这种符号的变量会以预编译的形式赋值到sql片段中。
${}:表示使用这种符号的变量会以字符串的形式直接插到sql片段中。
mybatis中支持三种语句类型,不同语句类型支持的变量符号不同。mybatis的三种类型如下:
STATEMENT
:这种语句类型中,只会对sql片段进行简单的字符串拼接。只支持使用${}.
PREPARED
:这种语句中会先对sql片段进行字符串拼接,然后再对sql片段进行赋值。可以使用#{}和${}.
CALLABLE
:这种语句用了实现执行过程的调用,会先对sql片段进行字符串拼接,然后对sql片段进行赋值。可以使用#{}和${}.
statement
子包负责提供语句处理功能,其中StatementHandler
是语句功能类的父接口,RoutingStatementHandler
类是一个代理类,它能够根据传入的MappedStatement
对象的具体类型选中一个具体的被代理对象,然后将所有实际操作都委托给被代理对象。所以RoutingStatementHandler类提供的是路由功能,而路由选择的依据就是语句类型。
publicclassRoutingStatementHandlerimplementsStatementHandler{//根据语句类型选取出的被代理类的对象privatefinalStatementHandlerdelegate;publicRoutingStatementHandler(Executorexecutor,MappedStatementms,Objectparameter,RowBoundsrowBounds,ResultHandlerresultHandler,BoundSqlboundSql){//根据语句类型选择被代理对象switch(ms.getStatementType()){caseSTATEMENT:delegate=newSimpleStatementHandler(executor,ms,parameter,rowBounds,resultHandler,boundSql);break;casePREPARED:delegate=newPreparedStatementHandler(executor,ms,parameter,rowBounds,resultHandler,boundSql);break;caseCALLABLE:delegate=newCallableStatementHandler(executor,ms,parameter,rowBounds,resultHandler,boundSql);break;default:thrownewExecutorException("Unknownstatementtype:"+ms.getStatementType());}}}
BaseStatementHandler
作为三个实现类的父类,提供了实现类的公共方法。并且BaseStatementHandler
类使用的模板模式在prepare
方法中定义了整个方法的框架,然后将一些与子类相关的操作交给三个子类处理。
SimpleStatementHandler
类、PreparedStatementHandler
类和CallableStatementHandler
类是三个真正的statement
处理器,分别处理statement、preparedStatement
、CallableStatement
对象。通过其中的parameterize
方法可以看出三个Statement
处理器的不同。
SimpleStatementHandler
中parameterize
方法的实现为空,因为它只需要完成字符串替换即可,不需要进行参数处理
publicclassSimpleStatementHandlerextendsBaseStatementHandler{@Overridepublicvoidparameterize(Statementstatement){//N/A}}
PreparedStatementHandler
中parameterize
方法最终通过ParameterHandler接口经过多级中转后调用了PreparedStatement类中的参数赋值方法。
publicclassPreparedStatementHandlerextendsBaseStatementHandler{@Overridepublicvoidparameterize(Statementstatement)throwsSQLException{parameterHandler.setParameters((PreparedStatement)statement);}}
CallableStatementHandler
中parameterize主要是通过registerOutputParameters方法中转后调用CallableStatement中的输出参数注册方法完成输出参数的注册,然后通过ParameterHandler接口经过多级中转后调用了PreparedStatement类中的参数赋值方法。
publicclassCallableStatementHandlerextendsBaseStatementHandler{/***对语句进行参数处理*@paramstatementSQL语句*@throwsSQLException*/@Overridepublicvoidparameterize(Statementstatement)throwsSQLException{//输出参数的注册registerOutputParameters((CallableStatement)statement);//输入参数的处理parameterHandler.setParameters((CallableStatement)statement);}}
以上就是关于“mybatis的executor包语句处理功能源码分析”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注亿速云行业资讯频道。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。