分页工具类

封装好的分页工具类PageSupport .java:
package org.openxtiger.common.page;
/**
* 分页工具类
* @author lunzi
* @since 2009-3-28
* @param <E>
*
* @version 0.1
*/
import java.util.ArrayList;
import java.util.List;

public class PageSupport {

private int totalCount = 0;//总记录数
private int pageCount;//总页数
private int pageSize = 10;//每页显示记录数
private int page = 1;//当前页
private int num = 5;//当前页之前和之后显示的页数个数 如:假设当前页是 6 共有11页 那么 显示分页条会显示 1 2 3 4 5 [6] 7 8 9 10 11
private List items = new ArrayList();//当前页记录内容集合

/**
* 计算总页数
* @param totalCount
*/
public void setTotalCount(int totalCount) {
if (totalCount > 0) {
this.totalCount = totalCount;
this.pageCount = (totalCount+pageSize-1)/pageSize;
}
}

/**
* 获取前一页
* @return
*/
public int getPrev(){
return page-1;
}

/**
* 获取后一页
* @return
*/
public int getNext(){
return page+1;
}

/**
* 获取最后一页
* @return
*/
public int getLast(){
return pageCount;
}

/**
* 判断是否有前一页
* @return
*/
public boolean getIsPrev(){
if(page>1){
return true;
}
return false;
}

/**
* 判断是否有后一页
* @return
*/
public boolean getIsNext(){
if(page<pageCount){
return true;
}
return false;
}

/**
* 当前页的前num条页 假设当前页是 6 共有11页 如:1 2 3 4 5
* @return
*/
public List<Integer> getPrevPages() {
List<Integer> list = new ArrayList<Integer>();
int _frontStart = 1;

if (page > num) {
_frontStart = page - num;
}


for (int i=_frontStart; i<page; i++) {
list.add(i);
}

return list;
}

/**
* 当前页的后num条页 假设当前页是 6 共有11页 如:7 8 9 10 11
* @return
*/
public List<Integer> getNextPages() {
List<Integer> list = new ArrayList<Integer>();
int _endCount = num;

if (num < pageCount && (page+num)<pageCount) {
_endCount = page+_endCount;
}

for (int i=page+1;i<=_endCount; i++) {
list.add(i);
}

return list;
}

/**
* 获取每页显示记录数
* @return
*/
public int getPageSize() {
return pageSize;
}

/**
* 设置每页显示记录数
* @param pageSize
*/
public void setPageSize(int pageSize) {
this.pageSize = pageSize;
}

/**
* 得到当前页数
* @return
*/
public int getPage() {
return page;
}

/**
* 设置当前页数
* @param page
*/
public void setPage(int page) {
this.page = page;
}

/**
* 获取当前页之前或之后显示的页数个数
* @return
*/
public int getNum() {
return num;
}

/**
* 设置当前页之前或之后显示的页数个数
* @param num
*/
public void setNum(int num) {
this.num = num;
}

/**
* 获取当前页记录内容集合
* @return
*/
public List getItems() {
return items;
}

/**
* 设置当前页记录内容集合
* @param items
*/
public void setItems(List items) {
this.items = items;
}

/**
* 获取总记录数
* @return
*/
public int getTotalCount() {
return totalCount;
}

/**
* 得到总页数
* @return
*/
public int getPageCount() {
return pageCount;
}

}



分页使用模拟测试:
模型类News.java

package test.util.page;
/**
* 分页工具模拟内容实体类
* @author lunzi
* @since 2009-3-28
* @param <E>
*
* @version 0.1
*/
public class News {
private int id;

public News(int id) {
super();
this.id = id;
}

public int getId() {
return id;
}

public void setId(int id) {
this.id = id;
}

}
测试类PageSupportTest.java:
package test.util.page;
/**
* 分页工具模拟测试类
* @author lunzi
* @since 2009-3-28
* @param <E>
*
* @version 0.1
*/
import java.util.ArrayList;
import java.util.List;

import org.openxtiger.common.page.PageSupport;

public class PageSupportTest {

public static void main(String[] args) {

PageSupport pageSupport = new PageSupport();

pageSupport.setPage(5);//假设当前页为第5页
pageSupport.setPageSize(10);//设置每页显示10条记录
pageSupport.setTotalCount(100);//假设有100条记录
pageSupport.setNum(3);//假设当前页之前和之后显示的页数个数为3

List<News> newsList = new ArrayList<News>();

/**
* 给当前页记录内容集合赋值
*/
for(int i=(pageSupport.getPage()-1)*pageSupport.getPageSize();i<pageSupport.getPageSize()*pageSupport.getPage();i++){
newsList.add(new News(i));
}

pageSupport.setItems(newsList);

System.out.println("是否有下一页:"+pageSupport.getIsNext());
System.out.println("是否有上一页:"+pageSupport.getIsPrev());

System.out.println("当前第"+pageSupport.getPage()+"页");
System.out.println("共有"+pageSupport.getPageCount()+"页");
System.out.println("每页显示"+pageSupport.getPageSize()+"记录");
System.out.println("共有"+pageSupport.getTotalCount()+"条记录");

System.out.println("模拟的新闻ID:");
for(News o : newsList){
System.out.println(o.getId());
}

/**
* 分页导航条
*/
System.out.println("分页导航条");
for(Integer o:pageSupport.getPrevPages()){
System.out.print(o+",");
}

System.out.print("["+pageSupport.getPage()+"]");
for(Integer o:pageSupport.getNextPages()){
System.out.print(o+",");
}
}

}
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、付费专栏及课程。

余额充值