黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

mongodb查詢分頁優(yōu)化

系統(tǒng) 2471 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循環(huán)可以這么寫

int index=0;

while(cursor.hasNext()&index<limit){//確保循環(huán)十次,讓集合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來進一步縮小查詢范圍.
?

未完待續(xù)

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

?

mongodb查詢分頁優(yōu)化


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發(fā)表我的評論
最新評論 總共0條評論