如何在聚合查询中获得 $avg 的“-无穷”结果?


为此,您可以使用 aggregate()。让我们首先创建一个包含无穷小值(-infinity)作为值的文档集合 −

> db.demo5.insertOne({ "_id" : 100, "seq" : 10, "Value" : -Infinity });
{ "acknowledged" : true, "insertedId" : 100 }
> db.demo5.insertOne({ "_id" : 101, "seq" : 10, "Value" : 50 });
{ "acknowledged" : true, "insertedId" : 101 }
> db.demo5.insertOne({ "_id" : 102, "seq" : 20, "Value" : 60 });
{ "acknowledged" : true, "insertedId" : 102 }
> db.demo5.insertOne({ "_id" : 103, "seq" : 20, "Value" : 50 });
{ "acknowledged" : true, "insertedId" : 103 }

以下是使用 find() 方法显示某个集合中所有文档的查询 −

> db.demo5.find();

这将产生以下输出 &miuns;

{ "_id" : 100, "seq" : 10, "Value" : -Infinity }
{ "_id" : 101, "seq" : 10, "Value" : 50 }
{ "_id" : 102, "seq" : 20, "Value" : 60 }
{ "_id" : 103, "seq" : 20, "Value" : 50 }

以下是针对聚合查询中 $avg 获取“-无穷”结果的查询。基于 seq,找到了平均值。这将得到 -Infinity −

> db.demo5.aggregate([{$group:{"_id":"$seq", "average" : {$avg : "$Value"}}}]);

这将产生以下输出 −

{ "_id" : 20, "average" : 55 }
{ "_id" : 10, "average" : -Infinity }

更新日期:2020 年 4 月 1 日

127 次浏览

开启你的 职业

通过完成该课程获取认证

开始学习
广告