若依框架mybatis分页失效,只能查出10条数据

2024-03-12 20:44

本文主要是介绍若依框架mybatis分页失效,只能查出10条数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题背景

在使用MyBatis-Plus进行项目开发时,遇到了分页查询功能失效的问题。具体表现是在执行分页查询后,始终只能获取到10条数据,同时返回的总记录数也不准确。经过排查发现,这是因为误用了selectVoList方法,该方法并不支持分页处理,返回的是未进行分页的ArrayList类型。

问题分析

首先,我们来看一下原代码片段:

// 启动分页
startPage();// 执行查询
List<SysExceptionLog> list = exceptionLogService.selectExceptionLogList(dto);// 将查询结果封装为TableDataInfo对象
return getDataTable(list);

服务端业务逻辑中,selectExceptionLogList方法的内容如下:

public List<SysExceptionLog> selectExceptionLogList(SysExceptionLogDTO dto) {// 构建查询条件LambdaQueryWrapper<SysExceptionLog> lqw = Wrappers.lambdaQuery();// ...(具体的查询条件)// 使用selectVoList方法进行查询,该方法不支持分页return exceptionLogMapper.selectVoList(lqw);
}

getDataTable方法则是将查询结果封装为前端需要的分页格式:

protected <T> TableDataInfo<T> getDataTable(List<T> list) {TableDataInfo<T> rspData = new TableDataInfo<>();rspData.setCode(HttpStatus.SUCCESS);rspData.setMsg("查询成功");rspData.setRows(list);// 试图通过PageInfo计算总记录数,但由于list不是分页查询结果,所以total值不准确rspData.setTotal(new PageInfo(list).getTotal());return rspData;
}

解决方案

为了解决这个问题,我们需要对selectExceptionLogList方法进行调整,使其支持分页查询。首先,需要将查询方法的返回类型改为MyBatis-Plus提供的IPage接口的实现类,如Page,并在查询前启动分页。

服务端代码调整
// 启动分页,传入当前页码和每页大小
Page<SysExceptionLog> page = new Page<>(dto.getPageNum(), dto.getPageSize());
startPage(page);// 调整selectExceptionLogList方法以返回IPage类型结果
IPage<SysExceptionLog> pageInfo = exceptionLogService.selectExceptionLogList(dto);// 将IPage对象传递给getDataTable方法
return getDataTable(pageInfo);

然后,修改selectExceptionLogList方法:

public IPage<SysExceptionLog> selectExceptionLogList(SysExceptionLogDTO dto) {LambdaQueryWrapper<SysExceptionLog> lqw = Wrappers.lambdaQuery();// ...(保持原有的查询条件不变)// 使用IPage作为返回类型,并进行分页查询return exceptionLogMapper.selectPage(page, lqw);
}

最后,更新getDataTable方法以便直接从IPage对象获取总记录数:

protected <T> TableDataInfo<T> getDataTable(IPage<T> pageInfo) {TableDataInfo<T> rspData = new TableDataInfo<>();rspData.setCode(HttpStatus.SUCCESS);rspData.setMsg("查询成功");rspData.setRows(pageInfo.getRecords()); // 分页查询结果集rspData.setTotal(pageInfo.getTotal()); // 正确的总记录数return rspData;
}

图解–debug

​​​​​​debug对比图

总结

通过以上调整,我们成功解决了MyBatis-Plus分页查询失效的问题,现在可以根据请求参数正确获取并返回带分页信息的数据。这再次强调了在使用ORM框架进行分页查询时,需确保使用支持分页特性的方法,并正确处理和返回分页相关的信息。

这篇关于若依框架mybatis分页失效,只能查出10条数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/802521

相关文章

MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析

《MyBatis-Plus中Service接口的lambdaUpdate用法及实例分析》本文将详细讲解MyBatis-Plus中的lambdaUpdate用法,并提供丰富的案例来帮助读者更好地理解和应... 目录深入探索MyBATis-Plus中Service接口的lambdaUpdate用法及示例案例背景

MyBatis-Plus中静态工具Db的多种用法及实例分析

《MyBatis-Plus中静态工具Db的多种用法及实例分析》本文将详细讲解MyBatis-Plus中静态工具Db的各种用法,并结合具体案例进行演示和说明,具有很好的参考价值,希望对大家有所帮助,如有... 目录MyBATis-Plus中静态工具Db的多种用法及实例案例背景使用静态工具Db进行数据库操作插入

通过ibd文件恢复MySql数据的操作方法

《通过ibd文件恢复MySql数据的操作方法》文章介绍通过.ibd文件恢复MySQL数据的过程,包括知道表结构和不知道表结构两种情况,对于知道表结构的情况,可以直接将.ibd文件复制到新的数据库目录并... 目录第一种情况:知道表结构第二种情况:不知道表结构总结今天干了一件大事,安装1Panel导致原来服务

Jmeter如何向数据库批量插入数据

《Jmeter如何向数据库批量插入数据》:本文主要介绍Jmeter如何向数据库批量插入数据方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Jmeter向数据库批量插入数据Jmeter向mysql数据库中插入数据的入门操作接下来做一下各个元件的配置总结Jmete

Python结合Flask框架构建一个简易的远程控制系统

《Python结合Flask框架构建一个简易的远程控制系统》这篇文章主要为大家详细介绍了如何使用Python与Flask框架构建一个简易的远程控制系统,能够远程执行操作命令(如关机、重启、锁屏等),还... 目录1.概述2.功能使用系统命令执行实时屏幕监控3. BUG修复过程1. Authorization

MyBatis的配置对象Configuration作用及说明

《MyBatis的配置对象Configuration作用及说明》MyBatis的Configuration对象是MyBatis的核心配置对象,它包含了MyBatis运行时所需的几乎所有配置信息,这个对... 目录MyBATis配置对象Configuration作用Configuration 对象的主要作用C

MyBatis与其使用方法示例详解

《MyBatis与其使用方法示例详解》MyBatis是一个支持自定义SQL的持久层框架,通过XML文件实现SQL配置和数据映射,简化了JDBC代码的编写,本文给大家介绍MyBatis与其使用方法讲解,... 目录ORM缺优分析MyBATisMyBatis的工作流程MyBatis的基本使用环境准备MyBati

SpringBoot集成图片验证码框架easy-captcha的详细过程

《SpringBoot集成图片验证码框架easy-captcha的详细过程》本文介绍了如何将Easy-Captcha框架集成到SpringBoot项目中,实现图片验证码功能,Easy-Captcha是... 目录SpringBoot集成图片验证码框架easy-captcha一、引言二、依赖三、代码1. Ea

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

MySQL InnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据

《MySQLInnoDB引擎ibdata文件损坏/删除后使用frm和ibd文件恢复数据》mysql的ibdata文件被误删、被恶意修改,没有从库和备份数据的情况下的数据恢复,不能保证数据库所有表数据... 参考:mysql Innodb表空间卸载、迁移、装载的使用方法注意!此方法只适用于innodb_fi