mongodb查询分页优化

要求不用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来进一步缩小查询范围.
 

未完待续

以上方法有不当之处,欢迎批评指正,如果好的方法,希望能交流一下

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

郭梧悠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值