java分页之假分页实现简单的分页器

网友投稿 305 2023-07-18


java分页之假分页实现简单的分页器

import java.util.Arrays;

import java.util.Collections;

import java.util.List;

/**

* @author shuang.gao Date: 2016/1/28 Time: 12:26

*/

public class Pager {

/**

* 每页显示条数

*/

private int pageSize;

/**

* 原集合

*/

private List data;

private Pager(List 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 业务对象

* @return 分页器

*/

public static Pager create(List data, int pageSize) {

return new Pager<>(data, pageSize);

}

/**

* 得到分页后的http://数据

*

* @param pageNum 页码

* @return 分页后结果

*/

public List 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 getData() {

return data;

}

public static void main(String[] args) {

Integer[] array = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12};

List list = Arrays.asList(array);

Pager pager = Pager.create(list, 10);

List page1 = pager.getPagedList(1);

System.out.println(page1);

List page2 = pager.getPagedList(2);

System.out.println(page2);

List page3 = pager.getPagedList(3);

System.out.println(page3);

}

}

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

import java.util.Arrays; 

import java.util.Collections; 

import java.util.List; 

 

/**

 * @author shuang.gao  Date: 2016/1/28 Time: 12:26

 */ 

public class Pager

 

    /**

     * 每页显示条数

     */ 

    private int pageSize; 

    /**

     * 原集合

     */ 

    private List data; 

 

    private Pager(List data, int pageSize) { 

        if (data == null || data.isEmpty()) { 

            throw new IllegalArgumentException("data must be not empty!"); 

        } 

 

        this.data = data; 

        this.pageSize = pageSize; 

    } 

 

    /**

     * 创建分页器

     *

     * @param data 需要分页的数据

  &nbshttp://p;  * @param pageSize 每页显示条数

     * @param 业务对象

     * @return 分页器

     */ 

    public static Pager create(List data, int pageSize) { 

        return new Pager<>(data, pageSize); 

    } 

 

    /**

     * 得到分页后的数据

     *

     * @param pageNum 页码

     * @return 分页后结果

     */ 

    public List 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 getData() { 

        return data; 

    } 

 

    public static void main(String[] args) { 

        Integer[] array = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12}; 

        List list = Arrays.asList(array); 

 

        Pager pager = Pager.create(list, 10); 

 

        List page1 = pager.getPagedList(1); 

        System.out.println(page1); 

 

        List page2 = pager.getPagedList(2); 

        System.out.println(page2); 

 

        List page3 = pager.getPagedList(3); 

        System.out.println(page3); 

    } 

这是一个简单的分页器,原理很简单,将从数据库查询的数据,传入到分页器里,返回的是分好页的集合。

优点是兼容所有JDBC数据库,缺点是这种方法不适用于大批量数据。

以上就是本文的全部内容,希望对大家的学习有所帮助。


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:对比Java设计模式编程中的状态模式和策略模式
下一篇:详解Java设计模式编程中命令模式的项目结构实现
相关文章

 发表评论

暂时没有评论,来抢沙发吧~