工作中遇到的疑难杂症,以及解决办法

本文描述了在SpringBoot项目中,使用PageHelper实现分页时遇到拦截器失效的问题,原因在于PageHelper分页拦截器优先执行导致自定义拦截器被覆盖。解决方法是降低PageHelper版本并移除Spring集成包,恢复责任链模式的拦截顺序。

一  pagehelper和自定义mybatis拦截器冲突bug

1.1 问题描述

当在springboot工程,持久层使用mybatis,且使用pagehelper实现分页功能,当随着业务发展,需要自定义一个mybatis的拦截器实现sql的打印,但是出现拦截器失效,无法进入interceptor方法里面。

1.自定义的拦截器

2.使用pagehelper

1.2 问题原因

发现自定义拦截器与pagehelper定义分页拦截器有冲突,pagehelper分页拦截器先调用,他在调用完成后没有往下调。由于mybatis的拦截器为责任链模式调用,有一个传递机制。

1.3 解决办法

1.在pom文件中,将pagehelper和spring集成版本改成pagehelper的原生态版本,如下:

    <!-- 分页插件 -->
<!--    <dependency>-->
<!--      <groupId>com.github.pagehelper</groupId>-->
<!--      <artifactId>pagehelper-spring-boot-starter</artifactId>-->
<!--      <version>1.2.13</version>-->
<!--    </dependency>-->
    <dependency>
      <groupId>com.github.pagehelper</groupId>
      <artifactId>pagehelper</artifactId>
      <version>5.3.0</version>
    </dependency>

2.执行结果: 可以看到进入interceptor方法中,sql语句进行了输出。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值