溫馨提示×

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

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

jsp之分頁

發(fā)布時(shí)間:2020-07-14 16:51:55 來源:網(wǎng)絡(luò) 閱讀:1018 作者:W_Yinbin 欄目:開發(fā)技術(shù)

1. 如何控制每頁顯示數(shù)據(jù)量?

若每頁的數(shù)量為pageSize, 總數(shù)量為totalSize,那么在oracle數(shù)據(jù)庫中的sql語句應(yīng)該如何去書寫.首先假設(shè)每頁顯示數(shù)量為5,總數(shù)量為21,使用的表名為topic那么顯示前5條數(shù)據(jù)的sql語句為:

select t.*,rownum r from topic t where rownum < 6;

那么第二頁的數(shù)據(jù)又該如何去寫?若是按以下寫法會(huì)出現(xiàn)什么情況?

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

結(jié)果很明顯:沒有結(jié)果! 因?yàn)閞ownum偽列只會(huì)從第一個(gè)開始排序計(jì)算,而不能從第六位開始.但是如何取得第二頁數(shù)據(jù)?

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

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

這樣就可以查詢到第二頁數(shù)據(jù).


2. 如何計(jì)算頁數(shù)?

既然已經(jīng)知道了總數(shù)和每頁顯示的數(shù)目,那么總頁數(shù)也可以很容易計(jì)算. 若設(shè)每頁顯示數(shù)量為pageSize,總數(shù)量為totalSize,頁數(shù)為pageIndex.所以先從以下兩點(diǎn)考慮:

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

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

基于以上兩種情況,計(jì)算總頁數(shù)的方法可以設(shè)計(jì)為:

第一種方法:使用三目運(yùn)算符,若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轉(zhuǎn)為double類型,這樣所獲得的結(jié)果就是double類型,然后使用向上取整Math.ceil(double d),再將結(jié)果強(qiáng)轉(zhuǎn)為int型.

在這里也提一下向下取整吧.首先可以使用 Math.floor(double d)方法,也可以使用 int num = a / b;其中a,b為int類型,如果不是,可以進(jìn)行強(qiáng)轉(zhuǎn):int num = (int)(a / b);

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI