非SQL的自定义分页

当框架不支持复杂SQL分页时,本文介绍了一种应急方案:使用Java8的Stream流进行自定义分页。首先定义了一个Page类,包含分页大小和页码属性,并提供了获取起始位置的方法。然后通过Stream流,结合skip和limit方法实现分页,最后将流转换回集合。这种方法适用于数据量较小的情况,不适合长期大量使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

近期有个稍微复杂点的需求,但是框架中不支持复杂SQL的分页,换框架也来不及,最后想到使用Java8Stream来做一个自定义分页。(前提是数据量小的情况下,不建议长时间使用,偶尔应急可以用一下)

一、定义分页类

public class Page implements Serializable {
    private Integer pageSize =10;
    private Integer pageIndex =1;

    public Integer getPageSize() {
        return pageSize;
    }

    public void setPageSize(Integer pageSize) {
        this.pageSize = pageSize;
    }

    public Integer getPageIndex() {
        return pageIndex;
    }

    public void setPageIndex(Integer pageIndex) {
        this.pageIndex = pageIndex;
    }

    public int getStart(){
        return (pageIndex - 1) * pageSize;
    }

二、使用Stream流

List<User> users = userList.stream()  //首先将从数据库中查到的数据转为流
                .skip(page.getStart())  //使用skip()函数,这个函数的意思为跳过。需保证每次从数据库中查询的数据顺序一致。
                .limit(page.getPageSize()) // limit代表从第1位获取至 page.getPageSize位
                .collect(Collectors.toList());// 转为一个集合

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值