JAVA学习笔记_真假分页查询

在数据量大的情况下,分页查询是常见的处理方式。本文介绍了真假分页的概念,假分页通过查询所有数据后在内存中进行分页,虽然兼容性强但不适合大数据量。文章提供了Java中实现分页效果的代码示例,使用PageBean抽象记录,并通过集合的sublist方法获取分页数据。
摘要由CSDN通过智能技术生成

当要显示数据量足够大的时候,我们往往采用分页显示的处理办法。
———————————–分页有真分页和假分页—————————————

真分页:
确定要显示的数量和内容,然后每次都去数据库取出该少量数据,优点是数据量小,缺点是访问数据库频繁。
假分页:
从数据库中取出所有的数据,然后分页在界面上显示。访问一次数据库,但由于选择的数据量比较大,所以第一次花费时间比较长,但之后每一页的显示都是直接、快速的,避免对数据库的多次访问。

假分页,不是真正的在数据库里进行过滤,而是从数据库查询之后,取得全部结果,在展现的时候做些手脚。

真假分页辨别

看查询的SQL语句,如果一次取全部数据,就是假分页,如果SQL语句是取每页的数据条数,就是真分页

假分页

http://blog.csdn.net/ghsau/article/details/7243540
import java.util.Arrays;  
import java.util.Collections;  
import java.util.List;  


public class Pager<T> {
     

    /** 
     * 每页显示条数 
     */  
    private int pageSize;  
    /** 
     * 原集合 
     */  
    private List<T> data;  

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

        this.data = data;  
        this.pageSize = pageSize;  
    }  

    /** 
     * 创建分页器 
     * 
     * @param data 需要分页的数据 
     * @param pageSize 每页显示条数 
     * @param <T> 业务对象 
     * @return 分页器 
     */  
    public static <T> Pager<T> create(List<T> data, int pageSize) {  
        return new Pager<>(data, pageSize);  
    }  

    /** 
     * 得到分页后的数据 
     * 
     * @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);  
    }  

    public int getPageSize() {  
        return pageSize;  
    }  

    public List<T> getData() {  
        return data;  
    }  

    public static void main(String[] args) {  
        Integer[] array = {
  1, 2, 3, 4, 5, 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值