【问题标题】:How to add a custom field using mongo aggregation?如何使用 mongodb 聚合添加自定义字段?
【发布时间】:2021-06-12 16:17:28
【问题描述】:

我收藏的一个文档的结构如下:

{
    "tracking": [
        {
            "track_id": "abcd",
            "track_name": "Sample track"
        }, {...}, ...
    ]
}

我在一个名为 tracking 的数组中有多个这样的对象。现在我正在尝试使用 mongo 聚合添加一个名为 current_status 的字段,如下所示:

        {
            "$addFields": {
                "current_status": {
                    "$cond": {
                        "if": {"tracking.track_id": {"$in": ['abcd']}},
                        "then": "Approved",
                        "else": "Pending"
                    }
                }
            }
        }

运行后,我收到以下错误:

pymongo.errors.OperationFailure: Invalid $addFields :: caused by :: FieldPath field names may not contain '.'.

我想根据 track_id abcd 的对象是否存在于跟踪数组中,在 Mongo 聚合查询的结果中添加一个新字段。

【问题讨论】:

标签: mongodb mongodb-query aggregation-framework pymongo pymongo-3.x


【解决方案1】:

试试这个:

db.collection.aggregate([
    {
        "$addFields": {
            "tracking": {
                "$map": {
                    "input": "$tracking",
                    "as": "item",
                    "in": {
                        "$cond": {
                            "if": { "$eq": ["$$item.track_id", "abcd"] },
                            "then": {
                                "track_id": "$$item.track_id",
                                "track_name": "$$item.track_name",
                                "current_status": "Approved"
                            },
                            "else": {
                                "track_id": "$$item.track_id",
                                "track_name": "$$item.track_name",
                                "current_status": "Pending"
                            }
                        }
                    }
                }
            }
        }
    }
])

输出:

{
    "_id" : ObjectId("604f50859ee8b82dd8cd9f4a"),
    "tracking" : [
        {
            "track_id" : "abcd",
            "track_name" : "Sample track 1",
            "current_status" : "Approved"
        },
        {
            "track_id" : "fdsdf",
            "track_name" : "Sample track 2",
            "current_status" : "Pending"
        }
    ]
}

【讨论】:

  • 感谢您回复 Dheemanth,但我从上面的 cmets 得到了答复
猜你喜欢
  • 2022-11-23
  • 1970-01-01
  • 1970-01-01
  • 2021-06-26
  • 1970-01-01
  • 1970-01-01
  • 2021-03-20
  • 1970-01-01
  • 2016-08-04
相关资源
最近更新 更多