如何在聚合查询中获得 $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 }
广告