解决ruoyi框架中使用pagehelper插件分页查询后对数据进行对象转换后失效问题

本文主要是介绍解决ruoyi框架中使用pagehelper插件分页查询后对数据进行对象转换后失效问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、场景重现

使用rouyi框架时,可以看到很多分页查询,如:

//-----------SysConfigController-------------
@GetMapping("/list")
public TableDataInfo list(SysConfig config) {startPage();List<SysConfig> list = configService.selectConfigList(config);return getDataTable(list);
}//-----------SysConfigServiceImpl-------------
@Override
public List<SysConfig> selectConfigList(SysConfig config) {return configMapper.selectConfigList(config);
}

这里的分页就是使用pagehelper,很方便易用。
但如果需要将对象进行转换时,分页会失效,如:

//---------OrderController------------
@GetMapping("/list")
public TableDataInfo list(OrderDTO dto) {startPage();List<OrderDTO> list = orderService.selectOrderList(dto);return getDataTable(list);
}//---------OrderServiceImpl------------
@Override
public List<OrderDTO> selectOrderList(OrderDTO dto) {List<OrderDO> list = orderMapper.selectOrderList(dto);return list.stream().map(OrderDO::toDTO).collect(Collectors.toList());
}

此时会丢失total属性,导致无法正常分页。

二、方案一

请看代码:

//---------OrderController------------
@GetMapping("/list")
public TableDataInfo list(OrderDTO dto) {startPage();List<OrderDO> list = orderService.selectOrderList(dto);Page<OrderDTO> page = new Page<>();page.setTotal(PageInfo.of(list).getTotal());list.stream().map(OrderDO::toDTO).forEach(page::add);//或 list.forEach(item->page.add(item.toDTO()));//或 page.addAll(list.stream().map(OrderDO::toDTO).collect(Collectors.toList()));return getDataTable(page);
}//---------OrderServiceImpl------------
@Override
public List<OrderDTO> selectOrderList(OrderDTO dto) {return orderMapper.selectOrderList(dto);
}

Page类继承了ArrayList,看源码

package com.github.pagehelper;import ... ...public class Page<E> extends ArrayList<E> implements Closeable {... ...
}

所以可以直接使用BaseController中的getDataTable方法

//----------BaseController-------------
protected TableDataInfo getDataTable(List<?> list) {TableDataInfo rspData = new TableDataInfo();rspData.setCode(HttpStatus.SUCCESS);rspData.setRows(list);rspData.setMsg("查询成功");rspData.setTotal(new PageInfo(list).getTotal());return rspData;
}

也可以自己重载一下该方法

protected TableDataInfo convertDataTable(Page<?> page) {TableDataInfo rspData = new TableDataInfo();rspData.setCode(HttpStatus.SUCCESS);rspData.setRows(page.getResult());rspData.setMsg("查询成功");rspData.setTotal(page.getTotal());return rspData;
}

三、方案二

还有另外一种方案,与这个大差不差,就是自定义一个分页类

import lombok.Data;
import java.util.List;@Data
public class PageResult<T> {//状态码 0:成功 其他:失败private Integer code = 0;//页码private int pageNum;//分页大小private int pageSize;//总数private long total;//返回数据private List<T> data;//构造函数public PageResult(Integer code, PageLink pageLink, List<T> data) {this.code = code;this.pageNum = pageLink.getPageNum();this.pageSize = pageLink.getPageSize();this.total= pageLink.getTotal();this.data = data;}public static <T> PageResult success(PageLink pageLink, List<T> data) {return new PageResult<>(ResponseCode.OK, pageLink, data);}
}

接收前端的分页传值

@Data
public class PageLink {private int pageNum = 1;private int pageSize = 10;private long total;
}
//---------OrderController------------
@GetMapping(value = "/list")
public PageResult<OrderDTO> list(OrderDTO dto, PageLink pageLink) {List<OrderDTO> list = orderService.selectOrderList(dto, pageLink);return PageResult.success(pageLink, list);
}//---------OrderServiceImpl------------
@Override
public List<OrderDTO> selectOrderList(OrderDTO dto, PageLink pageLink) {// 分页查询PageInfo<OrderDO> pageInfo = PageHelper.startPage(pageLink.getPageNum(), pageLink.getPageSize()).doSelectPageInfo(() -> orderMapper.selectOrderList(dto));pageLink.setTotal(pageInfo.getTotal());return pageInfo.getList().stream().map(OrderDO::toDTO).collect(Collectors.toList());
}

这篇关于解决ruoyi框架中使用pagehelper插件分页查询后对数据进行对象转换后失效问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

关于MongoDB图片URL存储异常问题以及解决

《关于MongoDB图片URL存储异常问题以及解决》:本文主要介绍关于MongoDB图片URL存储异常问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录MongoDB图片URL存储异常问题项目场景问题描述原因分析解决方案预防措施js总结MongoDB图

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

Spring 请求之传递 JSON 数据的操作方法

《Spring请求之传递JSON数据的操作方法》JSON就是一种数据格式,有自己的格式和语法,使用文本表示一个对象或数组的信息,因此JSON本质是字符串,主要负责在不同的语言中数据传递和交换,这... 目录jsON 概念JSON 语法JSON 的语法JSON 的两种结构JSON 字符串和 Java 对象互转

最详细安装 PostgreSQL方法及常见问题解决

《最详细安装PostgreSQL方法及常见问题解决》:本文主要介绍最详细安装PostgreSQL方法及常见问题解决,介绍了在Windows系统上安装PostgreSQL及Linux系统上安装Po... 目录一、在 Windows 系统上安装 PostgreSQL1. 下载 PostgreSQL 安装包2.

Python使用getopt处理命令行参数示例解析(最佳实践)

《Python使用getopt处理命令行参数示例解析(最佳实践)》getopt模块是Python标准库中一个简单但强大的命令行参数处理工具,它特别适合那些需要快速实现基本命令行参数解析的场景,或者需要... 目录为什么需要处理命令行参数?getopt模块基础实际应用示例与其他参数处理方式的比较常见问http

python实现svg图片转换为png和gif

《python实现svg图片转换为png和gif》这篇文章主要为大家详细介绍了python如何实现将svg图片格式转换为png和gif,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录python实现svg图片转换为png和gifpython实现图片格式之间的相互转换延展:基于Py

C 语言中enum枚举的定义和使用小结

《C语言中enum枚举的定义和使用小结》在C语言里,enum(枚举)是一种用户自定义的数据类型,它能够让你创建一组具名的整数常量,下面我会从定义、使用、特性等方面详细介绍enum,感兴趣的朋友一起看... 目录1、引言2、基本定义3、定义枚举变量4、自定义枚举常量的值5、枚举与switch语句结合使用6、枚