【发布时间】: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 聚合查询的结果中添加一个新字段。
【问题讨论】:
-
尝试使用“tracking$track_id”
-
不工作,抛出以下错误 pymongo.errors.OperationFailure: Invalid $addFields :: 由 :: Expression $in 引起,正好需要 2 个参数。 1 个被传入。
-
使用
"if": {"$in": ["$tracking.track_id", ['abcd']},你混合了docs.mongodb.com/manual/reference/operator/query/in/index.html 和docs.mongodb.com/manual/reference/operator/aggregation/in/… -
谢谢@WernfriedDomscheit,它正在工作
标签: mongodb mongodb-query aggregation-framework pymongo pymongo-3.x