欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

mongodb查詢分頁優化

系統 2059 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元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产精品一区二区三区免费 | 亚洲天天更新 | 欧美久久久网站 | 一级特黄aaa免费 | 成人一级黄色大片 | 亚洲精品久久久久久久久久吃药 | 精品一区二区三区免费 | 性做久久久 | 在线一级片| 欧美无乱码久久久免费午夜一区 | 国产黄在线观看免费观看软件视频 | 亚洲国产成人在线 | 久久亚洲欧美日韩精品专区 | 欧美成人精品一区二区男人看 | 天天天天做夜夜夜夜 | 99re国产 | 国产淫视 | 欧美在线一区二区三区 | 午夜精品久久久久久99热软件 | 日本精品视频 | 欧美激烈大尺度叫床的床戏 | 亚洲五月婷 | 免费中文字幕 | 欧美精品网站 | 梦中人在线观看免费完整版 | 奇米第四色网站 | 一区二区三区免费在线 | 亚洲黄页 | 亚洲精品不卡 | 欧美成人伊人久久综合网 | 国产精品一级香蕉一区 | 国产在线视频自拍 | 一级做a爰片性色毛片视频图片 | 免费观看成人碰视频公开 | 免费观看日韩大尺码观看 | 成人欧美s视频在线观看 | wankzhd | 黑人精品欧美一区二区蜜桃 | 日本高清视频在线播放 | 久久久一区二区精品 | 国产精品久久久久久亚洲色 |