91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jsp之分頁

發布時間:2020-07-14 16:51:55 來源:網絡 閱讀:1067 作者:W_Yinbin 欄目:開發技術

1. 如何控制每頁顯示數據量?

若每頁的數量為pageSize, 總數量為totalSize,那么在oracle數據庫中的sql語句應該如何去書寫.首先假設每頁顯示數量為5,總數量為21,使用的表名為topic那么顯示前5條數據的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偽列只會從第一個開始排序計算,而不能從第六位開始.但是如何取得第二頁數據?

其實可以先創建一個虛擬表,虛擬表中含有一個偽列rownum,然后再查詢這個虛擬表中的rownum,此時的rownum可以看做一個實際的列,具體代碼如下:

select * from (select t.*,rownum r from topic t) where r>5 and r<=10;

這樣就可以查詢到第二頁數據.


2. 如何計算頁數?

既然已經知道了總數和每頁顯示的數目,那么總頁數也可以很容易計算. 若設每頁顯示數量為pageSize,總數量為totalSize,頁數為pageIndex.所以先從以下兩點考慮:

(1) 若totalSize/pageSize 正好等于一個整數,則這個整數就是頁數;

(2) 若totalSize/pageSize 不等于某一個整數,也就是說最后一頁顯示的數目小于pageSize,此時的頁數是(totalSize/pageSize)的整數部分 +1.

基于以上兩種情況,計算總頁數的方法可以設計為:

第一種方法:使用三目運算符,若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);

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

民丰县| 龙岩市| 大港区| 绥中县| 三台县| 乳源| 新源县| 惠来县| 垫江县| 临武县| 林芝县| 瑞昌市| 古交市| 石阡县| 进贤县| 天水市| 达州市| 施甸县| 方山县| 平顶山市| 平顺县| 顺义区| 耒阳市| 呈贡县| 隆尧县| 承德县| 宽城| 武威市| 神农架林区| 福清市| 侯马市| 台中市| 墨竹工卡县| 隆昌县| 通辽市| 湄潭县| 丰台区| 梓潼县| 班玛县| 台前县| 玉龙|