直接上代码如下:
package com.company.core.entity;
import java.util.Collections;
import java.util.List;
import org.apache.commons.lang.StringUtils;
import org.springframework.data.domain.Slice;
/**
* 与具体ORM实现无关的分页参数及查询结果封装. 注意所有序号从1开始.
*
* @param <T>
* Page中记录的类型.
*
* @author calvin
*/
public class Page<T> {
// -- 公共变量 --//
/** 升序 */
public static final String ASC = "asc";
/** 降序 */
public static final String DESC = "desc";
// -- 分页参数 --//
/** 页号 */
protected int pageNumber = 1;
/** 页大小 */
protected int pageSize = 20;
/** 排序field */
protected String orderBy;
/** 排序方式: ASC/DESC */
protected String order = ASC;
/** 是否自动统计记录条数 */
protected boolean autoCount = true;
// -- 返回结果 --//
/** 返回记录结果 */
protected List<T> result = Collections.emptyList();
/** 记录条数 */
protected long totalCount = -1;
/** -- 构造函数 -- */
public Page() {
}
/**
* 带参构造函数
*
* @param pageSize
* 每页大小
*/
public Page(int pageSize) {
this.pageSize = pageSize;
}
// -- 访问查询参数函数 --//
/**
* 获得当前页的页号,序号从1开始,默认为1.
*
* @return 页号
*/
public int getPageNumber() {
return pageNumber;
}
/**
* 设置当前页的页号,序号从1开始,低于1时自动调整为1.
*
* @param pageNumber
* 页号
*/
public void setPageNumber(final int pageNumber) {
this.pageNumber = pageNumber;
if (pageNumber < 1) {
this.pageNumber = 1;
}
}
/**
* 获得每页的记录数量,默认为1.
*
* @return 返回页面大小
*/
public int getPageSize() {
return pageSize;
}
/**
* 设置每页的记录数量,低于1时自动调整为1.
*
* @param pageSize
* 页面大小
*/
public void setPageSize(final int pageSize) {
this.pageSize = pageSize;
if (pageSize < 1) {
this.pageSize = 1;
}
}
/**
* 根据pageNo和pageSize计算当前页第一条记录在总结果集中的位置,序号从1开始.
*
* @return 页面第一条记录的序号
*/
public int getFirst() {
return ((pageNumber - 1) * pageSize) + 1;
}
/**
* 获得排序字段,无默认值.多个排序字段时用','分隔.
*
* @return 排序字段
*/
public String getOrderBy() {
return orderBy;
}
/**
* 设置排序字段,多个排序字段时用','分隔.
*
* @param orderBy
* 排序字段
*/
public void setOrderBy(final String orderBy) {
this.orderBy = orderBy;
}
/**
* 设置排序字段,多个排序字段时用','分隔.
*
* @param orderBy
* 排序字段
*/
public void setOrderMsg(final String orderBy, final String order) {
setOrderBy(orderBy);
setOrder(order);
}
/**
* 获得排序方向.
*
* @return 排序方向
*/
public String getOrder() {
return order;
}
/**
* 设置排序方式向.
*
* @param order
* 可选值为desc或asc,多个排序字段时用','分隔.
*/
public void setOrder(final String order) {
// 检查order字符串的合法值
String[] orders = StringUtils.split(StringUtils.lowerCase(order), ',');
if (orders != null) {
for (String orderStr : orders) {
if (!StringUtils.equals(DESC, orderStr) && !StringUtils.equals(ASC, orderStr))
throw new IllegalArgumentException("order orientation" + orderStr + "not legal");
}
}
this.order = StringUtils.lowerCase(order);
}
/**
* 是否已设置排序字段,无默认值.
*
* @return 是否已设置排序字段
*/
public boolean isOrderBySetted() {
return (StringUtils.isNotBlank(orderBy) && StringUtils
.isNotBlank(order));
}
/**
* 查询对象时是否自动另外执行count查询获取总记录数, 默认为false.
*
* @return 是否自动统计
*/
public boolean isAutoCount() {
return autoCount;
}
/**
* 查询对象时是否自动另外执行count查询获取总记录数.
*
* @param autoCount
* 是否自动统计
*/
public void setAutoCount(final boolean autoCount) {
this.autoCount = autoCount;
}
/**
* 设置是否自动统计
*
* @param theAutoCount
* 是否自动统计
* @return 当前页面对象
*/
public Page<T> autoCount(final boolean theAutoCount) {
setAutoCount(theAutoCount);
return this;
}
// -- 访问查询结果函数 --//
/**
* 取得页内的记录列表.
*
* @return 返回查询结果
*/
public List<T> getResult() {
return result;
}
/**
* 设置页内的记录列表.
*
* @param result
* 查询结果
*/
public void setResult(final List<T> result) {
this.result = result;
}
/**
* 取得总记录数, 默认值为-1.
*
* @return 记录总数
*/
public long getTotalCount() {
return totalCount;
}
/**
* 设置总记录数.
*
* @param totalCount
* 设置记录总数
*/
public void setTotalCount(final long totalCount) {
this.totalCount = totalCount;
}
/**
* 根据pageSize与totalCount计算总页数, 默认值为-1.
*
* @return 总页数
*/
public long getTotalPages() {
if (totalCount < 0)
return -1;
long count = totalCount / pageSize;
if (totalCount % pageSize > 0) {
count++;
}
return count;
}
/**
* 是否还有下一页.
*
* @return 是否有下一页
*/
public boolean isHasNext() {
return (pageNumber + 1 <= getTotalPages());
}
/**
* 取得下页的页号, 序号从1开始. 当前页为尾页时仍返回尾页序号.
*
* @return 下页页号
*/
public int getNextPage() {
if (isHasNext())
return pageNumber + 1;
else
return pageNumber;
}
/**
* 是否还有上一页.
*
* @return 返回是否有前一页
*/
public boolean isHasPre() {
return (pageNumber - 1 >= 1);
}
/**
* 取得上页的页号, 序号从1开始. 当前页为首页时返回首页序号.
*
* @return 返回前一页叶号
*/
public int getPrePage() {
if (isHasPre())
return pageNumber - 1;
else
return pageNumber;
}
}