标签:.com param 入参 except resultset parameter cti env 执行
• Executor (update, query, flushStatements, commit, rollback,
getTransaction, close, isClosed)
• ParameterHandler (getParameterObject, setParameters)
• ResultSetHandler (handleResultSets, handleOutputParameters)
• StatementHandler (prepare, parameterize, batch, update, query)
1 FirstIntercepter=====>setProperties 2 FirstIntercepter====>pluginorg.apache.ibatis.executor.CachingExecutor@64485a47 3 FirstIntercepter====>pluginorg.apache.ibatis.scripting.defaults.DefaultParameterHandler@2f0a87b3 4 FirstIntercepter====>pluginorg.apache.ibatis.executor.resultset.DefaultResultSetHandler@4fcd19b3 5 FirstIntercepter====>pluginorg.apache.ibatis.executor.statement.RoutingStatementHandler@2fd66ad3 6 DEBUG 09-05 11:56:24,696 ==> Preparing: select * from employee where id=? (BaseJdbcLogger.java:159) 7 FirstIntercepter:===>intercept 8 DEBUG 09-05 11:56:24,722 ==> Parameters: 1(Integer) (BaseJdbcLogger.java:159) 9 DEBUG 09-05 11:56:24,739 <== Total: 1 (BaseJdbcLogger.java:159) 10 Employee [id=1, lastName=tom, gender=1, email=asd@qq.com, depid=null]
1 /** 2 * 完成插件签名: 3 * 告诉MyBatis当前插件用来拦截哪个对象的哪个方法 4 * type:要拦截的四大类型 5 * method:拦截那个方法 6 * args:这个方法的入参 7 * */ 8 @Intercepts({ 9 @Signature(type=StatementHandler.class, 10 method="parameterize", 11 args=java.sql.Statement.class 12 ) 13 }) 14 public class FirstIntercepter implements Interceptor
<!-- plugins 插件的配置 实际上是使用:intercepter原理代理的 --> <plugins> <plugin interceptor="mybatis.intercepter.FirstIntercepter"> <property name="param1" value="root"/> <property name="param2" value="root"/> </plugin> </plugins>
1 MySecondIntercepter====>setProperties:{param1=root} 2 FirstIntercepter====>pluginorg.apache.ibatis.executor.CachingExecutor@64485a47 3 MySecondIntercepter====>plugin:org.apache.ibatis.executor.CachingExecutor@64485a47 4 FirstIntercepter====>pluginorg.apache.ibatis.scripting.defaults.DefaultParameterHandler@2f0a87b3 5 MySecondIntercepter====>plugin:org.apache.ibatis.scripting.defaults.DefaultParameterHandler@2f0a87b3 6 FirstIntercepter====>pluginorg.apache.ibatis.executor.resultset.DefaultResultSetHandler@4fcd19b3 7 MySecondIntercepter====>plugin:org.apache.ibatis.executor.resultset.DefaultResultSetHandler@4fcd19b3 8 FirstIntercepter====>pluginorg.apache.ibatis.executor.statement.RoutingStatementHandler@2fd66ad3 9 MySecondIntercepter====>plugin:org.apache.ibatis.executor.statement.RoutingStatementHandler@2fd66ad3 10 DEBUG 09-05 12:07:01,928 ==> Preparing: select * from employee where id=? (BaseJdbcLogger.java:159) 11 MySecondIntercepter====>intercept:public abstract void org.apache.ibatis.executor.statement.StatementHandler.parameterize(java.sql.Statement) throws java.sql.SQLException 12 FirstIntercepter:===>intercept 13 DEBUG 09-05 12:07:01,954 ==> Parameters: 1(Integer) (BaseJdbcLogger.java:159) 14 DEBUG 09-05 12:07:01,968 <== Total: 1 (BaseJdbcLogger.java:159) 15 Employee [id=1, lastName=tom, gender=1, email=asd@qq.com, depid=null]
<!-- Employee getSelectEmp(Integer id); --> <select id="getSelectEmp" parameterType="java.lang.Integer" resultType="mybatis.bean.Employee"> select * from employee where id=#{id} </select>
1 @Intercepts({ 2 @Signature(type=StatementHandler.class, 3 method="parameterize", 4 args=java.sql.Statement.class 5 ) 6 })
业务逻辑intercept方法中
1 /** 2 * 1:业务逻辑处理的方法: 3 */ 4 @Override 5 public Object intercept(Invocation invocation) throws Throwable { 6 //在这里可以进行业务逻辑修改 7 System.out.println("FirstIntercepter:===>intercept"+invocation.getMethod()); 8 9 MetaObject metaObject = SystemMetaObject.forObject(invocation.getTarget()); 10 //拿到target的元数据 StatementHandler==>ParameterHandler===> 11 //DefaultParameterHandler==>>parameterObject 12 Object value = metaObject.getValue("parameterHandler.parameterObject"); 13 System.out.println("sql "+value.toString()); 14 //修改完sql语句要用的参数 15 metaObject.setValue("parameterHandler.parameterObject", 2); 16 Object object = invocation.proceed(); 17 return object; 18 }
1 DEBUG 09-05 12:36:23,387 ==> Preparing: select * from employee where id=? (BaseJdbcLogger.java:159) 2 MySecondIntercepter====>intercept:public abstract void org.apache.ibatis.executor.statement.StatementHandler.parameterize(java.sql.Statement) throws java.sql.SQLException 3 FirstIntercepter:===>interceptpublic abstract void org.apache.ibatis.executor.statement.StatementHandler.parameterize(java.sql.Statement) throws java.sql.SQLException 4 sql 1 5 DEBUG 09-05 12:36:23,418 ==> Parameters: 2(Integer) (BaseJdbcLogger.java:159) 6 DEBUG 09-05 12:36:23,432 <== Total: 1 (BaseJdbcLogger.java:159) 7 Employee [id=2, lastName=cat, gender=0, email=qwe@qq.com, depid=null]
标签:.com param 入参 except resultset parameter cti env 执行
原文地址:https://www.cnblogs.com/dgwblog/p/9591499.html