首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MongoDB骨料然后平均

MongoDB骨料然后平均
EN

Stack Overflow用户
提问于 2014-09-30 01:34:54
回答 1查看 234关注 0票数 1

我有一个MongoDB查询,它使用如下所示的聚合框架:

代码语言:javascript
复制
System._get_collection().aggregate([
        { "$match": {
            "system_id": system.id,
            "utc_timestamp": {
                "$gte": datetime.datetime.now().replace(hour=0, minute=0, second=0, microsecond=0) - datetime.timedelta(days=1),
                "$lt": datetime.datetime.now().replace(hour=0, minute=0, second=0, microsecond=0)
            }
        }},
        { "$group": {
            "_id": { "$dayOfYear": "$utc_timestamp" },
            "correct": {
                "$sum": { "$cond": [
                    { "$eq": [ "$status", 455 ]}, 1, 0
                ]}
            },
            "total_count": { "$sum": 1 }
        }},
        { "$project": {
            "correctness": {
                "$cond": [
                    { "$eq": [ "$correct", 0 ] },
                    0,
                    { "$multiply" : [{"$divide": [ "$correct", "$total_count" ]}, 100] }
                ]
            }
        }}
    ])

输出如下所示:

代码语言:javascript
复制
{'result': [{'_id': 272, 'correctness': 99.89373007438896}], 'ok': 1.0}

我想在结果中添加一个字段,这是每个匹配的delay文档中所有System字段的平均值。

我试图将"delay": { "$avg": "$delay" },添加到$group部分,但没有更改结果。

我想要这样的结果:

代码语言:javascript
复制
{'result': [{'_id': 272, 'correctness': 99.89373007438896, 'delay': 5}], 'ok': 1.0}

注意上面的'delay': 5,它应该是计算的平均值。

我需要把这个加到投影中吗?或者,我是不是做错了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-09-30 02:04:59

除了_id之外,您从$project中省略的任何字段都不包含在输出中,因此只需将delay添加到其中:

代码语言:javascript
复制
{ "$project": {
    "correctness": {
        "$cond": [
            { "$eq": [ "$correct", 0 ] },
            0,
            { "$multiply" : [{"$divide": [ "$correct", "$total_count" ]}, 100] }
        ]
    },
    "delay": 1
}}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26111436

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档