免费高清特黄a大片,九一h片在线免费看,a免费国产一级特黄aa大,国产精品国产主播在线观看,成人精品一区久久久久,一级特黄aa大片,俄罗斯无遮挡一级毛片

分享

HibernatePage.java

 I_T_館 2014-05-10
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;
    }
}

    本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內容均由用戶發(fā)布,不代表本站觀點。請注意甄別內容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權內容,請點擊一鍵舉報。
    轉藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多