分页获取集合数据

package com.gws.utils;

import java.util.Collections;
import java.util.List;

/**
 * 【list实现分页获取】
 *
 */
public class ListPageUtil<T> {

    /**
     * 每页显示条数
     */
    private int pageSize;

    /**
     * 总页数
     */
    private int pageCount;

    /**
     * 原集合
     */
    private List<T> data;

    public ListPageUtil(List<T> data, int pageSize) {
        if (data == null || data.isEmpty()) {
            throw new IllegalArgumentException("data must be not empty!");
        }

        this.data = data;
        this.pageSize = pageSize;
        this.pageCount = data.size()/pageSize;
        if(data.size()%pageSize!=0){
            this.pageCount++;
        }
    }

    /**
     * 得到分页后的数据
     *
     * @param pageNum 页码
     * @return 分页后结果
     */
    public List<T> getPagedList(int pageNum) {
        int fromIndex = (pageNum - 1) * pageSize;
        if (fromIndex >= data.size()) {
            return Collections.emptyList();
        }

        int toIndex = pageNum * pageSize;
        if (toIndex >= data.size()) {
            toIndex = data.size();
        }
        return data.subList(fromIndex, toIndex);
    }
}

只需要将集合和每页条数传进去,在用方法获取数据就可以了。

 List<NewGameIndex> newGameIndices = new ArrayList<>();
        ListPageUtil  pageUtil = new ListPageUtil(newGameIndices,pageSize);
        List<NewGameIndex> gameIndices = pageUtil.getPagedList(currentPage);
        if (CollectionUtils.isEmpty(gameIndices)){
            return Collections.EMPTY_LIST;
        }

        return gameIndices;

### 使用Java实现分页获取数据 #### Hibernate分页实现 在Hibernate中,可以通过设置查询对象的`setFirstResult()`和`setMaxResults()`方法来控制分页行为。这种方式能够有效地减少数据库的压力并提高性能。 ```java Query query = session.createQuery("FROM User"); query.setFirstResult((currentPage - 1) * pageSize); query.setMaxResults(pageSize); List<User> users = query.list(); ``` 此代码片段展示了如何通过指定当前页面索引(`currentPage`)以及每页显示记录数(`pageSize`)来进行分页操作[^1]。 #### MyBatis分页插件PageHelper 对于MyBatis而言,则推荐使用PageHelper插件完成分页逻辑。只需引入依赖,在执行SQL之前调用相应API即可轻松达成目的。 ```xml <!-- Maven Dependency --> <dependency> <groupId>com.github.pagehelper</groupId> <artifactId>pagehelper</artifactId> <version>x.x.x</version> </dependency> ``` ```java // Before executing SQL statement PageHelper.startPage(currentPage, pageSize); // Execute your mapper method here... List<Item> itemList = itemMapper.selectAllItems(); // Automatically handles pagination after execution. ``` 上述例子说明了利用PageHelper简化MyBatis下的分页处理过程。 #### 基于Redis的分页方案 当面对海量数据场景时,采用关系型数据库的传统分页机制可能存在性能瓶颈。此时可考虑借助NoSQL解决方案——如Redis提供的列表(List)结构配合命令`LRANGE`或有序集合(Sorted Set)`ZRANGE`实现高效分页访问。 ```java Jedis jedis = new Jedis("localhost"); // Assuming we have a sorted set named 'scores' Set<String> pageOfScores = jedis.zrange("scores", (startOffset), (endOffset)); for(String score : pageOfScores){ System.out.println(score); } ``` 这里给出了一种基于Redis Sorted Sets类型的简单分页展示方式[^3]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值