对list进行分页

由于mybatis的分页插件PageHelper使用时只对紧随 PageHelper.startPage(pageNum, pageSize);  后面执行的一条sql语句进行分页,有时用不成!

分页实体类:

package com.mfc.entity;

import java.util.List;

public class ListSub<E> {
	private int pageNum; //当前页
	private int pages;   //总页数
	private int total;   //总条数
	private int pageSize;//每页显示数
	private List<E> list;//要进行分页的list
	
 	public ListSub(int pageNum, int pageSize, List<E> list) {
		super();
		this.pageNum = pageNum;
		this.pageSize = pageSize;
		this.list = list;
	}

	public int getPageNum() {
		return pageNum;
	}

	public void setPageNum(int pageNum) {
		this.pageNum = pageNum;
	}

	public int getPages() {
		if(this.total % this.pageSize == 0){
			this.pages = this.total / this.pageSize;
		}else{
			this.pages = this.total / this.pageSize+1;
		}
		return pages;
	}

	public void setPages(int pages) {
		this.pages = pages;
	}

	public int getTotal() {
		total = list.size();
		return total;
	}

	public void setTotal(int total) {
		this.total = total;
	}

	public int getPageSize() {
		return pageSize;
	}

	public void setPageSize(int pageSize) {
		this.pageSize = pageSize;
	}

	public List<E> getList() {
		List<E> newList = this.list.subList(pageSize*(pageNum-1), (pageSize*pageNum)>total?total:(pageSize*pageNum));
		return newList;
	}

	public void setList(List<E> list) {
		this.list = list;
	}
	
	
}

调用方法:

	public ListSub<Greens> getCategoryGreensList(int pageNum,int pageSize){
		List<Category> categories = categoryDao.getAllCategory();
		List<Greens> greens = new ArrayList<Greens>();
		for (Category category : categories) {
			List<Greens> greens2 = categoryDao.getCategoryGreensListByCategoryId(category.getCateId());
			for (Greens greens3 : greens2) {
				greens.add(greens3);
			}
		}
		ListSub<Greens> listSub = new ListSub<Greens>(pageNum, pageSize, greens);
		
		listSub.getPageNum();
		listSub.getPages();
		listSub.getTotal();
		listSub.getPageSize();
		return listSub;
	}

测试可用!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
list分页 import java.util.ArrayList; import java.util.List; import com.jsp.vo.Client; /** * PageBean * * @author apple * */ public class Page { private int currentPage; // 当前页数 private int totalPages; // 总页数 private int pageRows =8; // 每页显示记录数 private int totalRows; // 总数据数 private int specPages; // 指定页数 private int pageStartRow ; // 每页的起始数 private int pageEndRow; // 每页的终止数 private boolean hasNextPage; // 是否有下一页 private boolean hasPreviousPage; // 是否有前一页 private List list; /** * 初始化对象 * * @param tempList * 结果集 * */ public Page(List tempList,int pageRows) { this.list = tempList; this.pageRows = pageRows; this.totalRows = tempList.size(); this.currentPage = 1; // 获取总页数 if ((totalRows % pageRows) == 0) { totalPages = totalRows / pageRows; if(this.totalRows == 0 ){ this.pageRows = 0; } } else { totalPages = totalRows / pageRows + 1; } this.hasPreviousPage = false; // 是否有下一页 if (currentPage == totalPages) { hasNextPage = false; } else { hasNextPage = true; } this.pageStartRow = 0; if (totalRows < pageRows) { this.pageEndRow = totalRows; } else { this.pageEndRow = pageRows; } } /** * 获取当前页的对象集合 * * @return List 对象集合 */ public List getCurrentPageList() { if (currentPage * pageRows < totalRows) { pageEndRow = currentPage * pageRows; pageStartRow = pageEndRow - pageRows; } else { pageEndRow = totalRows; pageStartRow = pageRows * (totalPages - 1); } List pageList = new ArrayList(); for (int i = pageStartRow; i < pageEndRow; i++) { pageList.add(list.get(i)); } return pageList; } /** * 获取上一页的对象集合 * * @return List 对象集合 */ public List getPreviousPage() { currentPage--; if (currentPage = totalPages) { hasNextPage = false; } else { hasNextPage = true; } if (
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值