栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

SpringBoot+MongoDB查询大数据字段优化

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SpringBoot+MongoDB查询大数据字段优化

记录一下

SpringBoot+MongoDB查询大数据字段,查询的单个字段或者总查询结果量太大

用 mongoTemplate.find(query, NewSnapshot.class, collectionName); 查询比较慢

刚开始是这样查询的

public List  sss(String a,String b,String c) {

   Query query = new Query(Criteria.where("a").is(a).and("b").is(b));
   query.with(Sort.by(Sort.Order.asc("update_time")));
   List result = mongoTemplate.find(query, NewSnapshot.class, collectionName);
   return result;
}

结果1M数据量,单个字段40k的情况下,压测结果,110/s

修改为

public  List  newSnapshotPage2(String a,String b,String c) {

   MongoCollection collection = mongoTemplate.getCollection(a);
   FindIterable findIterable = collection.find(new Document("b",b).append("c",c));
   MongoCursor mongoCursor = findIterable.iterator();
   Xxx   xxx = new Xxx ();
   List result = new ArrayList<>();
   while (mongoCursor.hasNext()){
      Document next = mongoCursor.next();
      xxx .setA(next.get("1").toString());
      xxx .setP(next.get("2").toString());
      xxx .setU(next.get("3").toString());
      xxx .setB(next.get("4").toString());
      result.add(xxx);
   }
   return result;
}

同样的设备压测结果为,187/s

 性能是提升很多的。

新人没有逻辑,只为自己记录。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/871760.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号