亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

mongodb查詢分頁優化

系統 2279 0

要求不用skip

前提:1.時間倒序排列(自己現在的項目中也是按照時間倒序排列的)
????? 2.每頁顯示10條數據

int limit = 10;//剛開始點擊查詢的時候設置十條
查詢形式為 db.find(query).sort(time,-1).limit(limit)方式

注:query是查詢條件,其中包括了時間段的條件,例如 a=<time<=b的限制

1)記錄每一頁的第一條數據的時間firstTime
2)記錄每一頁最后一條數據的時間lastTime

?? ?
??? 在查詢之前判斷用戶是點擊下一頁還是上一頁,在這里用clickPrePage的值是否為空來判斷是否點擊上一頁
同理用clickNextPage的值是否為空來判斷是否點擊下一頁
?? ?
??? //邏輯代碼如下? ?
??? if(notEmpty(clickPrePage){//點擊上一頁
?????? limit = clickPrePage*10;
?????? 查詢條件的時間條件設置為>=firstTime??? ?
??? }//end if
?? ?
??? if(notEmpty(clickNextPage){//點擊下一頁
??????? limit = clickNextPage * 10;
??????? 查詢條件的時間條件設置為<=lastTime
??? }//end if
?

代碼說明:
?? 比如當前頁是第5頁,當點擊第4頁的時候,由于每頁要顯示十條,所以按照上面的邏輯limit=40,也就是查詢40條,取后十條記錄顯示即可
?? 同理,當點擊第6頁的時候。此時limit=60,查詢60條,取最后十條顯示
?? 當然,當用戶輸入跳轉的時候同樣的邏輯,比如當前頁還是取第五頁為例,此時用戶要跳轉到第100頁,那么此時limit=1000,取最后10條顯示即可

由于每頁顯示10條數據,需要從查詢的結果中獲取10條,所以while循環可以這么寫

int index=0;

while(cursor.hasNext()&index<limit){//確保循環十次,讓集合list的size=10,把list傳到前臺,來達到每頁顯示十條數據的目的

??? int i = limit-index;
?? ?
?? //查詢結果放入集合list中,要取查詢結果的后10條
?? if(i<10){? ?
? ?
???? //記錄每頁第一條數據的時間
????? if(i==9){
??????? fistTime = db.get("time").toString();
????? }
???? ?
????? //記錄每頁最后一條數據的時間
????? if(i==0){?? ?
????????? lastTime = db.get("time").toString();
????? }
????? list.add(cursor.hasNext().next());
?? }//end if
? ?
??? index++; ?
?? ?
}//end while

缺點:
? 在跨頁跳轉時由于不能確定要跳轉的頁面的前一頁的lastTime,所以根據前面設定的limit,需要查詢一些不必要的數據,? 然后從這些數據取后10條也就是需要的數據來顯示,效率上仍有些欠缺。
? ? 比如:當前頁為currentPage,記錄此頁的lastTime假設為a,要跳轉到currentPage+100頁,需要根據currentPage的lastTime來作為查詢條件,而沒法獲取currengPage+99頁的數據的lastTime來進一步縮小查詢范圍.
?

未完待續

以上方法有不當之處,歡迎批評指正,如果好的方法,希望能交流一下

?

mongodb查詢分頁優化


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲综合网址 | 天天干天天干天天干 | 九九热线 | 国产精品久久做爰 | 宅男在线看片 | 成人免费视频一区二区 | 久久久免费精品 | 久热re国产手机在线观看 | 日本一级特大毛片 | 精品国产福利久久久 | 免费爱爱小视频 | 久久久久一 | 精品久久免费视频 | 五月综合激情久久婷婷 | 第一福利视频 | 4虎影院午夜在线观看 | 成人毛片在线视频 | 久久国产精品无码网站 | 久久91精品牛牛 | 久久大香伊蕉在人线观看热2 | 日本亚洲精品一区二区三区 | 手机看片福利 | 国产亚洲精品久久久久91网站 | 亚洲成人国产 | 国产精品一区二区三 | 高清国产精品久久久久 | 亚洲视频一二三 | 一级片看看 | 在线日韩亚洲 | 全部毛片 | 99视频久久精品久久 | 日韩不卡一区二区三区 | 日本二级毛片免费 | 国产精品中文字幕在线 | 奇米影视首页 | 337p日本大胆欧洲色噜噜高清 | 日韩麻豆国产精品欧美 | 97色在线观看免费视频 | 欧美三级纯黄版 | 国产性色视频在线高清 | 四虎在线观看免费永久 |