package com.baihui.hxtd.soa.base.orm.hibernate; import org.apache.commons.lang3.StringUtils; import java.util.ArrayList; import java.util.List; /** * 與具體ORM實現(xiàn)無關的分頁參數(shù)及查詢結果封裝. * 注意所有序號從1開始. * * @param <T> Page中記錄的類型. */ public class HibernatePage<T> { //-- 公共變量 --// public static final String ASC = "asc"; public static final String DESC = "desc"; //-- 分頁參數(shù) --////為了和客戶端區(qū)page類中屬性分開 protected int pageNo = 1;//頁碼 protected int pageSize = -1;//每頁顯示條數(shù) protected String orderBy = null;//排序字段 protected String order = null;//排序方式 protected boolean autoCount = true; private int startPageIndex; // 顯示的頁碼列表的開始索引 private int endPageIndex; // 顯示的頁碼列表的結束索引 private int pageCount; //總頁數(shù) //-- 返回結果 --// protected List<T> result = new ArrayList<T>(); protected long totalCount = -1; //-- 構造函數(shù) --// public HibernatePage() { } public HibernatePage<T> end() { // 1, 總頁碼 pageCount = ((int) this.totalCount + pageSize - 1) / pageSize; // 2, startPageIndex(顯示的頁碼列表的開始索引)與endPageIndex(顯示的頁碼列表的結束索引) // a, 總頁碼不大于10頁 if (pageCount <= 10) { startPageIndex = 1; endPageIndex = pageCount; } // b, 總碼大于10頁 else { // 在中間,顯示前面4個,后面5個 startPageIndex = pageNo - 4; endPageIndex = pageNo + 5; // 前面不足4個時,顯示前10個頁碼 if (startPageIndex < 1) { startPageIndex = 1; endPageIndex = 10; } // 后面不足5個時,顯示后10個頁碼 else if (endPageIndex > pageCount) { endPageIndex = pageCount; startPageIndex = pageCount - 10 + 1; } } return this; } public HibernatePage(int pageSize) { this.pageSize = pageSize; } public HibernatePage(int pageNo, int pageSize) { this.pageNo = pageNo; this.pageSize = pageSize; } public HibernatePage(int pageNo, int pageSize, int totalCount) { this.pageNo = pageNo; this.pageSize = pageSize; this.totalCount = totalCount; } //-- 分頁參數(shù)訪問函數(shù) --// /** * 獲得當前頁的頁號,序號從1開始,默認為1. */ public int getHibernatePageNo() { return pageNo; } /** * 設置當前頁的頁號,序號從1開始,低于1時自動調整為1. */ public void setHibernatePageNo(final int pageNo) { this.pageNo = pageNo; if (pageNo < 1) { this.pageNo = 1; } } /** * 返回Page對象自身的setPageNo函數(shù),可用于連續(xù)設置。 */ public HibernatePage<T> pageNo(final int thePageNo) { setHibernatePageNo(thePageNo); return this; } /** * 獲得每頁的記錄數(shù)量, 默認為-1. */ public int getHibernatePageSize() { return pageSize; } /** * 設置每頁的記錄數(shù)量. */ public void setHibernatePageSize(final int pageSize) { this.pageSize = pageSize; } /** * 返回Page對象自身的setPageSize函數(shù),可用于連續(xù)設置。 */ public HibernatePage<T> pageSize(final int thePageSize) { setHibernatePageSize(thePageSize); return this; } /** * 根據(jù)pageNo和pageSize計算當前頁第一條記錄在總結果集中的位置,序號從1開始. */ public int getFirst() { return ((pageNo - 1) * pageSize) + 1; } /** * 獲得排序字段,無默認值. 多個排序字段時用','分隔. */ public String getHibernateOrderBy() { return orderBy; } /** * 設置排序字段,多個排序字段時用','分隔. */ public void setHibernateOrderBy(final String orderBy) { this.orderBy = orderBy; } /** * 返回Page對象自身的setOrderBy函數(shù),可用于連續(xù)設置。 */ public HibernatePage<T> orderBy(final String theOrderBy) { setHibernateOrderBy(theOrderBy); return this; } /** * 獲得排序方向, 無默認值. */ public String getHibernateOrder() { return order; } /** * 設置排序方式向. * * @param order 可選值為desc或asc,多個排序字段時用','分隔. */ public void setHibernateOrder(final String order) { if (order == null || "".equals(order)) return; String lowcaseOrder = StringUtils.lowerCase(order); //檢查order字符串的合法值 String[] orders = StringUtils.split(lowcaseOrder, ','); for (String orderStr : orders) { if (!StringUtils.equals(DESC, orderStr) && !StringUtils.equals(ASC, orderStr)) { throw new IllegalArgumentException("排序方向" + orderStr + "不是合法值"); } } this.order = lowcaseOrder; } /** * 返回Page對象自身的setOrder函數(shù),可用于連續(xù)設置。 */ public HibernatePage<T> order(final String theOrder) { setHibernateOrder(theOrder); return this; } /** * 是否已設置排序字段,無默認值. */ public boolean isOrderBySetted() { return (StringUtils.isNotBlank(orderBy) && StringUtils.isNotBlank(order)); } /** * 獲得查詢對象時是否先自動執(zhí)行count查詢獲取總記錄數(shù), 默認為false. */ public boolean isAutoCount() { return autoCount; } /** * 設置查詢對象時是否自動先執(zhí)行count查詢獲取總記錄數(shù). */ public void setAutoCount(final boolean autoCount) { this.autoCount = autoCount; } /** * 返回Page對象自身的setAutoCount函數(shù),可用于連續(xù)設置。 */ public HibernatePage<T> autoCount(final boolean theAutoCount) { setAutoCount(theAutoCount); return this; } //-- 訪問查詢結果函數(shù) --// /** * 獲得頁內的記錄列表. */ public List<T> getResult() { return result; } /** * 設置頁內的記錄列表. */ public void setResult(final List<T> result) { this.result = result; } /** * 獲得總記錄數(shù), 默認值為-1. */ public long getTotalCount() { return totalCount; } /** * 設置總記錄數(shù). */ public void setTotalCount(final long totalCount) { this.totalCount = totalCount; } /** * 根據(jù)pageSize與totalCount計算總頁數(shù), 默認值為-1. */ public long getTotalPages() { if (totalCount < 0) { return -1; } long count = totalCount / pageSize; if (totalCount % pageSize > 0) { count++; } return count; } /** * 是否還有下一頁. */ public boolean isHasNext() { return (pageNo + 1 <= getTotalPages()); } /** * 取得下頁的頁號, 序號從1開始. * 當前頁為尾頁時仍返回尾頁序號. */ public int getNextPage() { if (isHasNext()) { return pageNo + 1; } else { return pageNo; } } /** * 是否還有上一頁. */ public boolean isHasPre() { return (pageNo - 1 >= 1); } /** * 取得上頁的頁號, 序號從1開始. * 當前頁為首頁時返回首頁序號. */ public int getPrePage() { if (isHasPre()) { return pageNo - 1; } else { return pageNo; } } /** * 根據(jù)pageNo和pageSize計算當前頁第一條記錄在總結果集中的位置,序號從0開始. * 用于Mysql,Hibernate. */ public int getOffset() { return ((pageNo - 1) * pageSize); } /** * 根據(jù)pageNo和pageSize計算當前頁第一條記錄在總結果集中的位置,序號從1開始. * 用于Oracle. */ public int getStartRow() { return getOffset() + 1; } /** * 根據(jù)pageNo和pageSize計算當前頁最后一條記錄在總結果集中的位置, 序號從1開始. * 用于Oracle. */ public int getEndRow() { return pageSize * pageNo; } /** * 獲取頁碼列表的開始索引 * * @return */ public int getStartPageIndex() { return startPageIndex; } /** * 設置頁碼列表的開始索引 * * @param startPageIndex */ public void setStartPageIndex(int startPageIndex) { this.startPageIndex = startPageIndex; } /** * 獲取頁碼列表的結束索引 * * @return */ public int getEndPageIndex() { return endPageIndex; } /** * 設置頁碼列表的結束索引 * * @param endPageIndex */ public void setEndPageIndex(int endPageIndex) { this.endPageIndex = endPageIndex; } /** * 獲取總頁數(shù) * * @return */ public int getPageCount() { return pageCount; } /** * 設置總頁數(shù) * * @param pageCount */ public void setPageCount(int pageCount) { this.pageCount = pageCount; } } |
|
來自: I_T_館 > 《hxtd Project》