mongodb系列之五:java分页优化

转载自:http://blog.csdn.net/maosijunzi/article/details/42101041

前面我们提到过,大数据量分页时,skip如果跳过大量的数据会很慢,这里针对这一情况,我们优化一下分页。

看代码:

[java]  view plain copy print ? 在CODE上查看代码片 派生到我的代码片
  1. /** 
  2.      * 大数据量数据分页优化 
  3.      * @param page 
  4.      * @param pageSize 
  5.      * @param lastId 上一页的最大id 
  6.      * @return 
  7.      */  
  8.     public List<User> largePageList(int page, int pageSize, int lastId) {  
  9.         DB myMongo = MongoManager.getDB("myMongo");  
  10.         DBCollection userCollection = myMongo.getCollection("user");  
  11.         DBCursor limit = null;  
  12.         if (page == 1) {  
  13.             limit = userCollection.find()  
  14.                     .sort(new BasicDBObject("id"1)).limit(pageSize);  
  15.         } else {  
  16.             limit = userCollection  
  17.                     .find(new BasicDBObject("id"new BasicDBObject(  
  18.                             QueryOperators.GT, lastId)))  
  19.                     .sort(new BasicDBObject("id"1)).limit(pageSize);  
  20.         }  
  21.   
  22.         List<User> userList = new ArrayList<User>();  
  23.         while (limit.hasNext()) {  
  24.             User user = new User();  
  25.             user.parse(limit.next());  
  26.             userList.add(user);  
  27.         }  
  28.         return userList;  
  29.     }  
  30.       
  31.       
  32.     public static void main(String[] args) {  
  33.         UserDao userDao = new UserDao();  
  34.         List<User> largePageList = userDao.largePageList(1,5,0);//第一页  
  35.         print(largePageList);  
  36.         System.out.println("============");  
  37.         List<User> largePageList2 = userDao.largePageList(2,5,5);//第二页   需要记录上一页的最大id  
  38.         print(largePageList2);  
  39.         System.out.println("============");  
  40.         List<User> largePageList3 = userDao.largePageList(3,5,11);//第三页   需要记录上一页的最大id  
  41.         print(largePageList3);  
  42.     }  
  43.       
  44.     public static void print(List<User> largePageList){  
  45.         for(User user : largePageList){  
  46.             System.out.println(user);  
  47.         }  
  48.     }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值