分页工具类

package net.pm.common.toolkit;

import java.util.ArrayList;
import java.util.List;

/**分页工具类
 * @param <T>
 */
@SuppressWarnings("unused")
public final class Pager<T> {

	/**当前页码
	 */
	private Integer pageno = PMConstant.PAGE_DEFAULT_NO;
	/** 当前页宽
	 */
	private Integer pagesize = PMConstant.PAGE_DEFAULT_SIZE;
	/**总页数
	 */
	private Integer pagecount;
	/**总记录数
	 */
	private Long totalsize;
	/**结果集
	 */
	private List<T> result;
	/**是否有下一页
	 */
	private Boolean hasPre;
	
	/**
	 * 上一页
	 */
	private Integer prePage;
	
	/**是否有上一页
	 */
	private Boolean hasNext;
	
	/**
	 * 下一页
	 */
	private Integer nextPage;
	
	/**
	 * 首页
	 */
	private Integer homePage;
	
	/**
	 * 尾页
	 */
	private Integer endPage;

	/**获取当前页码的前后X个页码的数字集合,
	 * @return 
	 */
	public List<Integer> getPageNumberList() {
		List<Integer> xlist = new ArrayList<Integer>();
		// 当前页的前x页
		int diff = this.pageno - PMConstant.PAGE_DEFAULT_X;
		int begin = diff > 0 ? diff : 1;
		diff = 0;
		// 当前页的后x页
		diff = this.pageno + PMConstant.PAGE_DEFAULT_X;
		int end = diff <= this.pagecount ? diff : this.pagecount;
		for (; begin <= end; begin++) {
			xlist.add(begin);
		}
		return xlist;
	}
	
	public Pager() {
		super();
	}

	public Pager(Integer pageno, Integer pagesize, Integer pagecount,
			long totalsize, List<T> result) {
		super();
		this.pageno = pageno;
		this.pagesize = pagesize;
		this.pagecount = pagecount;
		this.totalsize = totalsize;
		this.result = result;
	}

	public Integer getPageno() {
		return pageno;
	}

	public void setPageno(Integer pageno) {
		this.pageno = pageno;
	}

	public Integer getPagesize() {
		return pagesize;
	}

	public void setPagesize(Integer pagesize) {
		this.pagesize = pagesize;
	}

	public Integer getPagecount() {
		return pagecount;
	}

	public void setPagecount(Integer pagecount) {
		this.pagecount = pagecount;
	}

	public Long getTotalsize() {
		return totalsize;
	}

	public void setTotalsize(long totalsize) {
		this.totalsize = totalsize;
	}

	public List<T> getResult() {
		return result;
	}

	public void setResult(List<T> result) {
		this.result = result;
	}

	public Boolean getHasPre() {
		return this.pageno > 1;
	}

	public Boolean getHasNext() {
		return this.pageno < this.pagecount;
	}

	public Integer getPrePage() {
		return this.pageno - 1;
	}

	public Integer getNextPage() {
		return this.pageno + 1;
	}

	public Integer getHomePage() {
		return 1;
	}

	public Integer getEndPage() {
		return pagecount;
	}
	
	
	
}

转载于:https://my.oschina.net/foggy/blog/57443

MongoDB是一种NoSQL数据库,不同于传统关系型数据库,它采用了面向文档的数据存储方式。在MongoDB中没有内置的分页工具类,但我们可以通过编写自定义的分页工具类来满足分页查询的需求。 首先,我们需要一个方法来查询数据库中的文档并进行分页。我们可以使用MongoDB的find()方法来实现查询,并使用skip()和limit()方法来控制分页。skip()方法指定跳过的文档数量,limit()方法指定返回的文档数量。 在自定义分页工具类中,我们可以编写一个方法来执行分页查询。该方法有四个参数:页数、每页显示的数量、查询条件和排序方式。根据传入的参数,我们可以计算出需要跳过的文档数量和需要返回的文档数量,并使用find()、skip()和limit()方法执行查询。 除了基本的分页功能,我们还可以添加一些扩展功能,例如返回总页数和总记录数。我们可以通过计算数据库中的文档数量以及每页显示的数量,来得到总页数和总记录数。然后将这些信息添加到返回结果中,方便前端展示和操作。 需要注意的是,在执行分页查询时,我们需要根据查询条件和排序方式来调整和优化数据的查询和存储结构,以提高查询效率。例如,可以创建索引、使用合适的查询条件和排序方式等。 总而言之,MongoDB虽然没有内置的分页工具类,但我们可以通过编写自定义的分页工具类来实现分页查询。通过查询条件、页数和每页显示的数量,我们可以计算出需要跳过的文档数量和返回的文档数量,并使用MongoDB的find()、skip()和limit()方法来执行分页查询。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值