java mongodb cursor_MongoDB Java聚合函数的游标错误

我正在尝试从MongoDB中获取数据,以获得前5个最受欢迎的产品 . 但我收到了以下错误 . (MongoDB版本3.2.21)com.mongodb.MongoCommandException:命令失败,错误9:''cursor'选项是必需的,除了在服务器localhost:27017上使用explain参数的聚合 . 完整的响应是{“ok”:0.0,“errmsg”:“'cursor'选项是必需的,除了带有explain参数的聚合”,“code”:9,“codeName”:“FailedToParse”}

DBObject groupFields = groupFields = new BasicDBObject("_id", 0);

groupFields.put("_id", "$productId");

groupFields.put("avgRating", new BasicDBObject("$avg", "$productRvR"));

groupFields.put("productModelName", new BasicDBObject("$push", "$productMN"));

DBObject group = new BasicDBObject("$group", groupFields);

DBObject projectFields = new BasicDBObject("_id", 0);

projectFields.put("productId", "$_id");

projectFields.put("avgRating", "$avgRating");

projectFields.put("productModelName", "$productModelName");

DBObject project = new BasicDBObject("$project", projectFields);

DBObject sort = new BasicDBObject();

sort.put("avgRating",-1);

DBObject orderby=new BasicDBObject("$sort",sort);

DBObject limit=new BasicDBObject("$limit",5);

AggregationOutput aggregate userReviews.aggregate(group,project,orderby,limit);

LinkedHashMap mostLikedProductsMap = new LinkedHashMap();

for (DBObject queryResult : aggregate.results()) {

BasicDBObject obj = (BasicDBObject) queryResult;

BasicDBList productModelName = (BasicDBList) obj.get("productModelName");

mostLikedProductsMap.put((String)productModelName.get(0),obj.getString("avgRating"));

}

return mostLikedProductsMap;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值