解决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

相关文章

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同