ruoyi框架一对多连表分页查询工具

从若依框架中自带的PageUtils类中拷贝

若依框架自带的
import com.github.pagehelper.PageHelper;
import com.liary.common.core.page.PageDomain;
import com.liary.common.core.page.TableSupport;
import com.liary.common.utils.sql.SqlUtil;

/**
 * 分页工具类
 * 
 * @author liary
 */
public class PageUtils extends PageHelper
{
    /**
     * 设置请求分页数据
     */
    public static void startPage()
    {
        PageDomain pageDomain = TableSupport.buildPageRequest();
        Integer pageNum = pageDomain.getPageNum();
        Integer pageSize = pageDomain.getPageSize();
        String orderBy = SqlUtil.escapeOrderBySql(pageDomain.getOrderBy());
        Boolean reasonable = pageDomain.getReasonable();
        PageHelper.startPage(pageNum, pageSize, orderBy).setReasonable(reasonable);
    }

    /**
     * 清理分页的线程变量
     */
    public static void clearPage()
    {
        PageHelper.clearPage();
    }
}

自定义的分页工具类

package com.liary.common.utils.page;

import com.github.pagehelper.Page;
import com.github.pagehelper.PageInfo;
import com.liary.common.core.page.TableDataInfo;

import java.util.List;

/**
 * 分页工具类
 *
 * @author admin
 * @date 2024/03/20
 */
public class PaginationUtil {
    /**
     * 获取页面信息
     *
     * @param list        列表
     * @param currentPage 当前页面
     * @param pageSize    页面大小
     * @return {@link TableDataInfo}
     */
    public static <T> TableDataInfo getPageInfo(List<T> list, Integer currentPage, Integer pageSize) {
        int total = list.size();
        if (total > pageSize) {
            int toIndex = pageSize * currentPage;
            if (toIndex > total) {
                toIndex = total;
            }
            list = list.subList(pageSize * (currentPage - 1), toIndex);
        }
        Page<T> page = new Page<>(currentPage, pageSize);
        page.addAll(list);
        page.setPages((total + pageSize - 1) / pageSize);
        page.setTotal(total);

        PageInfo<T> pageInfo = new PageInfo<>(page);

        TableDataInfo rspData = new TableDataInfo();
        rspData.setRows(list);
        rspData.setTotal(pageInfo.getTotal());
        return rspData;
    }
}

== 获取分页参数==

 		//获取前端的分页参数
        PageDomain pageDomain = TableSupport.buildPageRequest();
        Integer pageNum = pageDomain.getPageNum();
        Integer pageSize = pageDomain.getPageSize();

在分页接口中使用

    @PostMapping("/list")
    public TableDataInfo list(LiaryTaskDetailDf taskDetailDf) {
        //获取前端的分页参数
        PageDomain pageDomain = TableSupport.buildPageRequest();
        Integer pageNum = pageDomain.getPageNum();
        Integer pageSize = pageDomain.getPageSize();

        //查询出的集合
        List<LiaryTaskDetailDf> list = liaryPregStatisticsService.getPregResultList(taskDetailDf);

        //使用自定义分页查询并返回数据
        return PaginationUtil.getPageInfo(list, pageNum, pageSize);
    }

原文链接:若依框架实现自定义分页查询_ruoyi自定义分页-CSDN博客

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值