Mybatis拦截器注解@Intercepts与@Signature注解属性说明

Mybatis拦截器注解@Intercepts与@Signature注解属性说明
可能有些新手使用mybatis拦截器的时候可能没太懂@Signature注解中type,method,args的用法

首先mybatis拦截器可以拦截如下4中类型

Executor sql的内部执行器
ParameterHandler 拦截参数的处理
StatementHandler 拦截sql的构建
ResultSetHandler 拦截结果的处理
@Signature 注解参数说明:
type:就是指定拦截器类型(ParameterHandler ,StatementHandler,ResultSetHandler )
method:是拦截器类型中的方法,不是自己写的方法
args:是method中方法的入参

举个例子

如下拦截器:

@Intercepts(value = {
        @Signature(type = ResultSetHandler.class, method = "handleResultSets", args = Statement.class),
})
@Component
public class MybatisResultSetHandler implements Interceptor {

    @Override
    public Object intercept(Invocation invocation) throws Throwable {
        //这里不管几个结果都是返回一个list,强转成list即可
        Object proceed = invocation.proceed();
        System.out.println(proceed);
        return proceed;
    }
}

type就是 拦截结果的处理(ResultSetHandler )的拦截器,method是ResultSetHandler 接口的某一个方法,args就是这个方法中的参数,复制即可:

public interface ResultSetHandler {
    <E> List<E> handleResultSets(Statement var1) throws SQLException;

    <E> Cursor<E> handleCursorResultSets(Statement var1) throws SQLException;

    void handleOutputParameters(CallableStatement var1) throws SQLException;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中,可以使用MyBatis框架来操作数据库。MyBatis提供了一个@Intercepts注解,可以用于拦截处理SQL语句的执行过程。 要实现对@Intercepts的过滤,首先需要在Spring Boot的配置文件中配置MyBatis拦截器。可以通过创建一个实现了Interceptor接口的类,并在该类上添加@Intercepts注解来定义拦截逻辑和拦截的方法。然后,在配置文件中配置这个拦截器拦截器可以拦截执行的SQL语句,并在执行之前或之后进行一些额外的处理。可以使用@Intercepts注解的type属性来指定要拦截的类和方法,例如: @Intercepts({ @Signature(type = StatementHandler.class, method = "prepare", args = { Connection.class, Integer.class }) }) public class MyInterceptor implements Interceptor { // 实现intercept方法,可以在此处编写拦截逻辑 // ... } 在这个例子中,使用@Intercepts注解指定了要拦截的类是StatementHandler,而拦截的方法是prepare。并且,还可以通过args属性来指定方法的参数,以进一步过滤要拦截的方法。 配置完成后,启动Spring Boot应用程序,MyBatis会自动将这个拦截器应用到所有符合拦截条件的SQL语句上。拦截器会在SQL语句执行前后进行相应的处理。 总之,通过配置@Intercepts注解,我们可以实现对MyBatis的SQL语句执行过程进行拦截和控制。这样可以在SQL语句执行前后进行一些额外的操作,例如:记录执行日志、修改SQL语句等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值