要求不用skip
前提:1.時間倒序排列(自己現(xiàn)在的項目中也是按照時間倒序排列的)
????? 2.每頁顯示10條數(shù)據(jù)
int limit = 10;//剛開始點擊查詢的時候設(shè)置十條
查詢形式為 db.find(query).sort(time,-1).limit(limit)方式
注:query是查詢條件,其中包括了時間段的條件,例如 a=<time<=b的限制
1)記錄每一頁的第一條數(shù)據(jù)的時間firstTime
2)記錄每一頁最后一條數(shù)據(jù)的時間lastTime
?? ?
??? 在查詢之前判斷用戶是點擊下一頁還是上一頁,在這里用clickPrePage的值是否為空來判斷是否點擊上一頁
同理用clickNextPage的值是否為空來判斷是否點擊下一頁
?? ?
??? //邏輯代碼如下? ?
??? if(notEmpty(clickPrePage){//點擊上一頁
?????? limit = clickPrePage*10;
?????? 查詢條件的時間條件設(shè)置為>=firstTime??? ?
??? }//end if
?? ?
??? if(notEmpty(clickNextPage){//點擊下一頁
??????? limit = clickNextPage * 10;
??????? 查詢條件的時間條件設(shè)置為<=lastTime
??? }//end if
?
代碼說明:
?? 比如當前頁是第5頁,當點擊第4頁的時候,由于每頁要顯示十條,所以按照上面的邏輯limit=40,也就是查詢40條,取后十條記錄顯示即可
?? 同理,當點擊第6頁的時候。此時limit=60,查詢60條,取最后十條顯示
?? 當然,當用戶輸入跳轉(zhuǎn)的時候同樣的邏輯,比如當前頁還是取第五頁為例,此時用戶要跳轉(zhuǎn)到第100頁,那么此時limit=1000,取最后10條顯示即可
由于每頁顯示10條數(shù)據(jù),需要從查詢的結(jié)果中獲取10條,所以while循環(huán)可以這么寫
int index=0;
while(cursor.hasNext()&index<limit){//確保循環(huán)十次,讓集合list的size=10,把list傳到前臺,來達到每頁顯示十條數(shù)據(jù)的目的
??? int i = limit-index;
?? ?
?? //查詢結(jié)果放入集合list中,要取查詢結(jié)果的后10條
?? if(i<10){? ?
? ?
???? //記錄每頁第一條數(shù)據(jù)的時間
????? if(i==9){
??????? fistTime = db.get("time").toString();
????? }
???? ?
????? //記錄每頁最后一條數(shù)據(jù)的時間
????? if(i==0){?? ?
????????? lastTime = db.get("time").toString();
????? }
????? list.add(cursor.hasNext().next());
?? }//end if
? ?
??? index++; ?
?? ?
}//end while
缺點:
? 在跨頁跳轉(zhuǎn)時由于不能確定要跳轉(zhuǎn)的頁面的前一頁的lastTime,所以根據(jù)前面設(shè)定的limit,需要查詢一些不必要的數(shù)據(jù),? 然后從這些數(shù)據(jù)取后10條也就是需要的數(shù)據(jù)來顯示,效率上仍有些欠缺。
? ? 比如:當前頁為currentPage,記錄此頁的lastTime假設(shè)為a,要跳轉(zhuǎn)到currentPage+100頁,需要根據(jù)currentPage的lastTime來作為查詢條件,而沒法獲取currengPage+99頁的數(shù)據(jù)的lastTime來進一步縮小查詢范圍.
?
未完待續(xù)
以上方法有不當之處,歡迎批評指正,如果好的方法,希望能交流一下
?
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
