1. 如何控制每頁顯示數據量?
java
若每頁的數量爲pageSize, 總數量爲totalSize,那麼在oracle數據庫中的sql語句應該如何去書寫.首先假設每頁顯示數量爲5,總數量爲21,使用的表名爲topic那麼顯示前5條數據的sql語句爲:sql
select t.*,rownum r from topic t where rownum < 6;
那麼第二頁的數據又該如何去寫?如果按如下寫法會出現什麼狀況?數據庫
select t.*,rownum r from topic t where rownum >5 and rownum < 10;
結果很明顯:沒有結果! 由於rownum僞列只會從第一個開始排序計算,而不能從第六位開始.可是如何取得第二頁數據?oracle
其實能夠先建立一個虛擬表,虛擬表中含有一個僞列rownum,而後再查詢這個虛擬表中的rownum,此時的rownum能夠看作一個實際的列,具體代碼以下:ide
select * from (select t.*,rownum r from topic t) where r>5 and r<=10;
這樣就能夠查詢到第二頁數據.設計
2. 如何計算頁數?排序
既然已經知道了總數和每頁顯示的數目,那麼總頁數也能夠很容易計算. 若設每頁顯示數量爲pageSize,總數量爲totalSize,頁數爲pageIndex.因此先從如下兩點考慮:it
(1) 若totalSize/pageSize 正好等於一個整數,則這個整數就是頁數;class
(2) 若totalSize/pageSize 不等於某一個整數,也就是說最後一頁顯示的數目小於pageSize,此時的頁數是(totalSize/pageSize)的整數部分 +1.select
基於以上兩種狀況,計算總頁數的方法能夠設計爲:
第一種方法:使用三目運算符,若totalSize正好被pageSize整除,那麼直接取totalSize/pageSize,不然取totalSize/pageSize + 1.
int pageIndex = totalSize % pageSize == 0 ? (totalSize/pageSize) : (totalSize/pageSize + 1);
第二種方法:使用向上取整方法:
int pageIndex = (int)(Math.ceil((double)totalSize/pageSize));
這裏首先要將totalSize或者是pageSize轉爲double類型,這樣所得到的結果就是double類型,而後使用向上取整Math.ceil(double d),再將結果強轉爲int型.
在這裏也提一下向下取整吧.首先能夠使用 Math.floor(double d)方法,也能夠使用 int num = a / b;其中a,b爲int類型,若是不是,能夠進行強轉:int num = (int)(a / b);