解决mybatis-plus 拦截器不生效--分页插件不生效

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Redis 版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 本文介绍了在使用 Mybatis-Plus 进行分页查询时遇到的问题及解决方法。依赖包包括 `mybatis-plus-boot-starter`、`mybatis-plus-extension` 等,并给出了正确的分页配置和代码示例。当分页功能失效时,需将 Mybatis-Plus 版本改为 3.5.5 并正确配置拦截器。

依赖包版本

com.baomidou:mybatis-plus-boot-starter:jar:3.5.5

com.baomidou:mybatis-plus-extension:jar:3.5.5

com.github.pagehelper:pagehelper-spring-boot-starter:jar:2.0.0

com.github.jsqlparser:jsqlparser:jar:4.5

com.github.pagehelper:sqlparser4.5:jar:6.1.0


参考文档: 官方分页插件  Mybatis-Plus分页不生效的一些原因总结_mybatisplus 分页不生效-CSDN博客  mybatisplus github.pagehelper的 jsqlparser冲突 - CSDN文库   MybatisPlus 分页查询不生效,拦截器无效的解决方案_mybatisplus拦截器不生效-CSDN博客  升级到最新版本后出现PageHelperAutoConfiguration Bad return type


现象


使用 `getMapper().selectPage(pagePlus, queryWrapper)` 查询时,没有分页,即SQL里面没有limit,同时也没有查询总条数,即 total为0;


public Page<T> selectPage(T entity, Page<T> page) {
        com.baomidou.mybatisplus.extension.plugins.pagination.Page<T> pagePlus =
                new com.baomidou.mybatisplus.extension.plugins.pagination.Page<>(page.getPageNum(), page.getPageSize());

        QueryWrapper<T> queryWrapper = new QueryWrapper<>(entity);
        queryWrapper.orderBy(StringUtils.isNotEmpty(page.getOrderBy())
                , page.getIsAsc().equals(SqlKeyword.ASC.getSqlSegment()), page.getOrderBy());

        com.baomidou.mybatisplus.extension.plugins.pagination.Page<T> tPage
                = getMapper().selectPage(pagePlus, queryWrapper);

        if (ObjectUtil.isNotNull(tPage)) {
            return new Page<>(tPage.getRecords(), tPage.getTotal());
        }
        return Page.empty();
    }



解决方法

  1. 把mybatis-plus相关依赖包的版本由3.5.7 改为3.5.5 ,(com.baomidou:mybatis-plus-boot-starter:jar:3.5.5)
  2. 修改mybatis 配置类,设置拦截器的方法不对.

old(有问题/错误):

sqlSessionFactoryBean.setPlugins(mybatisPlusInterceptor);


解决之后:

 SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBean.getObject();
        org.apache.ibatis.session.Configuration configuration = sqlSessionFactory.getConfiguration();
        if (mybatisPlusInterceptor != null) {
            configuration.addInterceptor(mybatisPlusInterceptor);
        }
  1. 去掉application.properties中的 `pagehelper.helperDialect=mysql` --解决  Invocation of init method failed; nested exception is java.lang.VerifyError: Bad return type

参考:

升级到最新版本后出现PageHelperAutoConfiguration Bad return type

Xnip 2024-09-17 12.27.14.png


完整代码:

@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor(PaginationInnerInterceptor paginationInnerInterceptor) {
    MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
    interceptor.addInnerInterceptor(paginationInnerInterceptor/*new PaginationInnerInterceptor(DbType.MYSQL)*/); // 根据你的数据库类型选择
    return interceptor;
}

    @Bean
    public PaginationInnerInterceptor getPaginationInnerInterceptor() {
        return new PaginationInnerInterceptor(DbType.MYSQL);
    } 

@Bean(name = "sqlSessionFactory")
    public SqlSessionFactory sqlSessionFactory(/*@Autowired*/ DataSource dataSource
                                               /*@Value("classpath:mybatis-config.xml") Resource configLocation,
                                               @Value("classpath:sqlmapper/*Mapper.xml") Resource[] mapperLocations*/, MybatisPlusInterceptor mybatisPlusInterceptor) throws Exception {
        MybatisSqlSessionFactoryBean sqlSessionFactoryBean = new MybatisSqlSessionFactoryBean();
        sqlSessionFactoryBean.setDataSource(dataSource);
        PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();

        //mapperLocation配置
        Resource[] resourcesWms = resolver.getResources("classpath*:/mapper/*Mapper.xml");
        Resource[] resourcesGform = resolver.getResources("classpath*:com//jobbook/mapper/xml/*Mapper.xml");
        Resource[] resourcesruoyiSys = resolver.getResources("classpath*:mapper/bbb/*Mapper.xml");
        Resource[] resourcesruoyiFlow = resolver.getResources("classpath*:mapper/ccc/*Mapper.xml");
        List<Resource> resourceList = Lists.newArrayList(resources);
//        resourceList.addAll(Arrays.asList(resourcesWms));
        resourceList.addAll(Arrays.asList(resourcesGform));
        resourceList.addAll(Arrays.asList(resourcesruoyiSys));
        resourceList.addAll(Arrays.asList(resourcesruoyiFlow));

        sqlSessionFactoryBean.setMapperLocations(resourceList.toArray(new Resource[]{}));
        SqlSessionFactory sqlSessionFactory = sqlSessionFactoryBean.getObject();
        org.apache.ibatis.session.Configuration configuration = sqlSessionFactory.getConfiguration();
        if (mybatisPlusInterceptor != null) {
            configuration.addInterceptor(mybatisPlusInterceptor);
        }

//        sqlSessionFactoryBean.setPlugins(mybatisPlusInterceptor);

        // 取得类型转换注册器
        TypeHandlerRegistry typeHandlerRegistry = sqlSessionFactory.getConfiguration().getTypeHandlerRegistry();
        // 注册默认枚举转换器
        typeHandlerRegistry.setDefaultEnumTypeHandler(org.apache.ibatis.type.EnumTypeHandler.class);
        return sqlSessionFactoryBean.getObject();
    }

分页SQL示例

   [com.industri.jobbook.aop.FlowDAOAop:process:31] - FlowDAOAop before: selectPage, args: [{"nodeList":[],"userList":[]},{"isAsc":"desc","orderBy":"create_time","pageNum":0,"pageSize":1,"total":0}]
2024-09-17 12:28:35.222 INFO  [traceId: ]-[http-nio-8080-exec-1]
                [com.alibaba.druid.pool.DruidDataSource:init:928] - {dataSource-1} inited
2024-09-17 12:28:40.909 DEBUG [traceId: ]-[http-nio-8080-exec-1]
                [org.apache.ibatis.logging.jdbc.BaseJdbcLogger:debug:135] - ==>  Preparing: SELECT COUNT(*) AS total FROM flow_definition WHERE del_flag = '0'
2024-09-17 12:28:40.933 DEBUG [traceId: ]-[http-nio-8080-exec-1]
                [org.apache.ibatis.logging.jdbc.BaseJdbcLogger:debug:135] - ==> Parameters: 
2024-09-17 12:28:41.482 DEBUG [traceId: ]-[http-nio-8080-exec-1]
                [org.apache.ibatis.logging.jdbc.BaseJdbcLogger:debug:135] - <==      Total: 1
2024-09-17 12:28:41.486 DEBUG [traceId: ]-[http-nio-8080-exec-1]
                [org.apache.ibatis.logging.jdbc.BaseJdbcLogger:debug:135] - ==>  Preparing: SELECT id,create_time,update_time,tenant_id,del_flag,flow_code,flow_name,version,is_publish,form_custom,form_path,activity_status,listener_type,listener_path,ext FROM flow_definition WHERE del_flag='0' ORDER BY create_time DESC LIMIT ?
2024-09-17 12:28:41.487 DEBUG [traceId: ]-[http-nio-8080-exec-1]
                [org.apache.ibatis.logging.jdbc.BaseJdbcLogger:debug:135] - ==> Parameters: 1(Long)
2024-09-17 12:28:42.017 DEBUG [traceId: ]-[http-nio-8080-exec-1]
                [org.apache.ibatis.logging.jdbc.BaseJdbcLogger:debug:135] - <==      Total: 1





相关文章
|
1月前
|
SQL XML Java
8、Mybatis-Plus 分页插件、自定义分页
这篇文章介绍了Mybatis-Plus的分页功能,包括如何配置分页插件、使用Mybatis-Plus提供的Page对象进行分页查询,以及如何在XML中自定义分页SQL。文章通过具体的代码示例和测试结果,展示了分页插件的使用和自定义分页的方法。
8、Mybatis-Plus 分页插件、自定义分页
|
1月前
|
Java 数据库 Spring
MyBatisPlus分页插件在SpringBoot中的使用
这篇文章介绍了如何在Spring Boot项目中配置和使用MyBatis-Plus的分页插件,包括创建配置类以注册分页拦截器,编写测试类来演示如何进行分页查询,并展示了测试结果和数据库表结构。
MyBatisPlus分页插件在SpringBoot中的使用
|
21天前
|
SQL Java 关系型数据库
MyBatis-Plus 分页魅力绽放!紧跟技术热点,带你领略数据分页的高效与便捷
【8月更文挑战第29天】在 Java 开发中,数据处理至关重要,尤其在大量数据查询与展示时,分页功能尤为重要。MyBatis-Plus 作为一款强大的持久层框架,提供了便捷高效的分页解决方案。通过封装数据库分页查询语句,开发者能轻松实现分页功能。在实际应用中,只需创建 `Page` 对象并设置页码和每页条数,再通过 `QueryWrapper` 构建查询条件,调用 `selectPage` 方法即可完成分页查询。MyBatis-Plus 不仅生成分页 SQL 语句,还自动处理参数合法性检查,并支持条件查询和排序等功能,极大地提升了系统性能和稳定性。
34 0
|
4天前
|
缓存 前端开发 Java
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
Soring Boot的起步依赖、启动流程、自动装配、常用的注解、Spring MVC的执行流程、对MVC的理解、RestFull风格、为什么service层要写接口、MyBatis的缓存机制、$和#有什么区别、resultType和resultMap区别、cookie和session的区别是什么?session的工作原理
【Java面试题汇总】Spring,SpringBoot,SpringMVC,Mybatis,JavaWeb篇(2023版)
|
20天前
|
Java 数据库连接 测试技术
SpringBoot 3.3.2 + ShardingSphere 5.5 + Mybatis-plus:轻松搞定数据加解密,支持字段级!
【8月更文挑战第30天】在数据驱动的时代,数据的安全性显得尤为重要。特别是在涉及用户隐私或敏感信息的应用中,如何确保数据在存储和传输过程中的安全性成为了开发者必须面对的问题。今天,我们将围绕SpringBoot 3.3.2、ShardingSphere 5.5以及Mybatis-plus的组合,探讨如何轻松实现数据的字段级加解密,为数据安全保驾护航。
65 1
|
28天前
|
Web App开发 前端开发 关系型数据库
基于SpringBoot+Vue+Redis+Mybatis的商城购物系统 【系统实现+系统源码+答辩PPT】
这篇文章介绍了一个基于SpringBoot+Vue+Redis+Mybatis技术栈开发的商城购物系统,包括系统功能、页面展示、前后端项目结构和核心代码,以及如何获取系统源码和答辩PPT的方法。
|
1月前
|
Java 关系型数据库 MySQL
1、Mybatis-Plus 创建SpringBoot项目
这篇文章是关于如何创建一个SpringBoot项目,包括在`pom.xml`文件中引入依赖、在`application.yml`文件中配置数据库连接,以及加入日志功能的详细步骤和示例代码。
|
13天前
|
Java 数据库连接 开发者
MyBatis-Plus整合SpringBoot及使用
MyBatis-Plus为MyBatis提供了强大的增强,使得在Spring Boot项目中的数据访问层开发变得更加快捷和简便。通过MyBatis-Plus提供的自动CRUD、灵活的查询构造器和简洁的配置,开发者
28 0
|
1月前
|
数据库
elementUi使用dialog的进行信息的添加、删除表格数据时进行信息提示。删除或者添加成功的信息提示(SpringBoot+Vue+MybatisPlus)
这篇文章介绍了如何在基于SpringBoot+Vue+MybatisPlus的项目中使用elementUI的dialog组件进行用户信息的添加和删除操作,包括弹窗表单的设置、信息提交、数据库操作以及删除前的信息提示和确认。
elementUi使用dialog的进行信息的添加、删除表格数据时进行信息提示。删除或者添加成功的信息提示(SpringBoot+Vue+MybatisPlus)
|
1月前
|
Java 测试技术 数据库
mybatisPlus在Springboot中的使用
这篇文章详细介绍了如何在Spring Boot项目中集成和使用MyBatis-Plus框架,包括依赖配置、数据库设置、项目结构、实体类定义、启动类配置、Mapper接口编写以及通过单元测试进行的增删改查操作示例。
mybatisPlus在Springboot中的使用