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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
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





相关文章
|
3月前
|
SQL Java 数据库连接
微服务——MyBatis分页
本文介绍了分页的多种实现方式,包括自带RowBounds分页、第三方插件PageHelper分页、SQL分页、数组分页及拦截器分页。其中,RowBounds是先查询全部结果再内存分页;PageHelper通过修改SQL动态添加分页关键字;SQL分页依赖数据库自身的分页功能如`LIMIT`;数组分页则是查询全量数据后用`subList`方法截取;拦截器分页则统一在SQL后添加分页语句。最后总结逻辑分页适合小数据量,但大数据量易内存溢出;物理分页虽小数据量效率较低,但更适合大数据场景,优先推荐使用。
60 0
|
3月前
|
SQL Oracle 关系型数据库
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
|
30天前
|
SQL Java 数据安全/隐私保护
发现问题:Mybatis-plus的分页总数为0,分页功能失效,以及多租户插件的使用。
总的来说,使用 Mybatis-plus 确实可以极大地方便我们的开发,但也需要我们理解其工作原理,掌握如何合适地使用各种插件。分页插件和多租户插件是其中典型,它们的运用可以让我们的代码更为简洁、高效,理解和掌握好它们的用法对我们的开发过程有着极其重要的意义。
208 15
|
3月前
|
SQL Java 关系型数据库
MyBatis篇-分页
本文介绍了多种分页方式,包括自带rowbound内存分页、第三方插件pagehelper(通过修改SQL实现分页)、SQL分页(依赖limit或rownum等关键字)、数组分页(先查询全部数据再用subList分页)、拦截器分页(自定义拦截器为SQL添加分页语句)。最后总结了逻辑分页(内存分页,适合小数据量)和物理分页(直接在数据库层面分页,适合大数据量)的优缺点,强调物理分页优先于逻辑分页。
|
3月前
|
SQL Java 数据库连接
MyBatis 实现分页的机制
MyBatis 的分页机制主要依赖于 `RowBounds` 对象和分页插件。`RowBounds` 实现内存分页,适合小数据量场景,通过设定偏移量和限制条数对结果集进行筛选。而针对大数据量,则推荐使用分页插件(如 PageHelper),实现物理分页。插件通过拦截 SQL 执行,动态修改语句添加分页逻辑,支持多种数据库方言。配置插件后,无需手动调整查询方法即可完成分页操作,提升性能与灵活性。
|
3月前
|
Oracle 关系型数据库 Java
|
3月前
|
XML Java 数据库连接
微服务——SpringBoot使用归纳——Spring Boot集成MyBatis——基于注解的整合
本文介绍了Spring Boot集成MyBatis的两种方式:基于XML和注解的形式。重点讲解了注解方式,包括@Select、@Insert、@Update、@Delete等常用注解的使用方法,以及多参数时@Param注解的应用。同时,针对字段映射不一致的问题,提供了@Results和@ResultMap的解决方案。文章还提到实际项目中常结合XML与注解的优点,灵活使用两者以提高开发效率,并附带课程源码供下载学习。
75 0
|
5月前
|
前端开发 Java 数据库连接
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
211 2
|
8月前
|
Java 数据库连接 Maven
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和MyBatis Generator,使用逆向工程来自动生成Java代码,包括实体类、Mapper文件和Example文件,以提高开发效率。
317 2
mybatis使用一:springboot整合mybatis、mybatis generator,使用逆向工程生成java代码。
|
8月前
|
SQL JSON Java
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块
这篇文章介绍了如何在Spring Boot项目中整合MyBatis和PageHelper进行分页操作,并且集成Swagger2来生成API文档,同时定义了统一的数据返回格式和请求模块。
205 1
mybatis使用三:springboot整合mybatis,使用PageHelper 进行分页操作,并整合swagger2。使用正规的开发模式:定义统一的数据返回格式和请求模块