如何在聚合查询中获得 $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 }
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
Javascript
PHP