gpt4 book ai didi

mongodb - 为什么在聚合查询中 $avg 会得到 "-Infinity"结果?

转载 作者:可可西里 更新时间:2023-11-01 10:03:50 26 4
gpt4 key购买 nike

我检索“每月平均百分比”的聚合查询返回了几个月的 -Infinity 平均值。什么会导致这种情况?

mycollection 中的相关属性是 mydatemynumericfield,它将百分比值存储为 double。

db.mycollection.aggregate(
[
{
$match: {
mydate: {
$gte: new Date(Date.UTC(2014, 8, 1)),
$lte: new Date(Date.UTC(2014, 12, 1)),
}
}
},
{
$group : {
_id : { month: { $month: "$mydate" }, year: { $year: "$mydate" } },
average: { $avg: "$mynumericfield" },
count: { $sum: 1 }
}
}

]
)

这是结果的示例:

/* 1 */
{
"result" : [
{
"_id" : {
"month" : 9,
"year" : 2014
},
"average" : 84.2586640583996598,
"count" : 20959.0000000000000000
},
{
"_id" : {
"month" : 11,
"year" : 2014
},
"average" : 96.9326915103888638,
"count" : 20743.0000000000000000
},
{
"_id" : {
"month" : 10,
"year" : 2014
},
"average" : -Infinity,
"count" : 20939.0000000000000000
},
{
"_id" : {
"month" : 12,
"year" : 2014
},
"average" : -Infinity,
"count" : 20913.0000000000000000
}
],
"ok" : 1.0000000000000000
}

最佳答案

我设法以某种方式重现了 -Infinity 问题,但规模较小。

让我们以示例集合 nums 为例,其中只有 4 个文档:

{ "_id" : 0, "grp" : 1, "mynum" : -Infinity }
{ "_id" : 1, "grp" : 1, "mynum" : 5 }
{ "_id" : 3, "grp" : 2, "mynum" : 8 }
{ "_id" : 4, "grp" : 2, "mynum" : 89 }

对该集合执行简单聚合,例如:

> db.nums.aggregate([{$group:{"_id":"$grp", "average" : {$avg : "$mynum"}}}])

给出以下结果:

{ "_id" : 2, "average" : 48.5 }
{ "_id" : 1, "average" : -Infinity }

这与您所经历的效果相同。

请尝试找出在您的集合中是否有一个包含 mynumericfield 且值为 -Infinity 的文档 - 也许您的情况与复制的类似:

> db.mycollection.find({mynumericfield : -Infinity})

希望对你有所帮助。

关于mongodb - 为什么在聚合查询中 $avg 会得到 "-Infinity"结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29509737/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com