当前位置: 首页 > news >正文

解决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<>();//赋值 pageSize、pageNum、totalBeanUtils.copyProperties(list, page);page.clear();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<OrderDO> selectOrderList(OrderDTO dto) {return orderMapper.selectOrderList(dto);
}

上面的代码可以简化一下,先抽离公共部分

protected <T, R> Page<R> converter(List<T> list, Function<T, R> converter) {Page<R> page = new Page<>();BeanUtils.copyProperties(list, page);page.clear();list.stream().map(converter).forEach(page::add);return page;
}

再进行改造

//---------OrderController------------
@GetMapping("/list")
public TableDataInfo list(OrderDTO dto) {startPage();List<OrderDO> list = orderService.selectOrderList(dto);Page<OrderDTO> page = converter(list, OrderDO::toDTO);return getDataTable(page);
}

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());
}
http://www.lryc.cn/news/432108.html

相关文章:

  • RabbitMQ 应用
  • 使用Python读取Excel数据的详细指南
  • VitePress 动态路由与路径加载器详解
  • C#编程语言及.NET 平台快速入门指南
  • 高等代数精解【9】
  • 谷粒商城の缓存篇
  • 永远学习:为什么人工智能难以适应新挑战
  • 【spring】 Jackson :@JsonIgnore 注解
  • Dependencies与DependencyManagement的区别
  • git svn 日记
  • FSMC
  • NAT技术+代理服务器+内网穿透
  • 【ABAP】ole2 excel多sheet导入导出
  • 图像配准-小结
  • 【2025】基于Python的空气质量综合分析系统的设计与实现(源码+文档+调试+答疑)
  • 计算机基础知识-2
  • Ubuntu2204配置连续失败后账户锁定
  • windows下安装elasticSearch和kibana
  • Java-IDEA模拟一个Redis服务器,与Redis客户端进行一次简单的交互。默认端口号:6379
  • WEB服务与虚拟主机/IIS中间件部署
  • JAVA开源项目 图书个性化推荐系统 计算机毕业设计
  • Spring Boot 注解探秘:HTTP 请求的魅力之旅
  • TYPE-C USB设计
  • Python炒股自动化,怎样理解股票交易性质
  • Vue2 day-02
  • 什么?!新版 Node.js V22.5 自带 SQLite 模块啦
  • Maven持续集成(Continuous integration,简称CI)版本友好管理
  • EvoSuite使用总结
  • Cortex-A7:简单中断处理(不可嵌套中断)机制
  • k8s HPA