如何将逗号分隔的字符串字段转换为 MongoDB 中的对象数组?

我有三个看起来像这样的文件:

_id: ObjectId('61e1312ad435c7124aa883a1')
name: "Brian"
languages: "English,Spanish,French"

_id: ObjectId('52e1312ad435c7124aa883a2')
name: "Max"
languages: "English"

_id: ObjectId('37e1312ad435c7124aa883a9')
name: "Mike"
languages: ""

如您所见,语言字段可以为空、有一个项目或多个项目,以逗号分隔。

如何将语言字段转换为对象数组?最终结果应如下所示:

_id: ObjectId('61e1312ad435c7124aa883a1')
name: "Brian"
languages: [
    { name: "English", active: false }
    { name: "Spanish", active: false }
    { name: "French", active: false }
]

_id: ObjectId('52e1312ad435c7124aa883a2')
name: "Max"
languages: [
    { name: "English", active: false }
]

_id: ObjectId('37e1312ad435c7124aa883a9')
name: "Mike"
languages: []

语言字段应该是一个包含两个字段的对象数组,一个“名称”字段是语言的名称,一个“活动”字段始终设置为 false。

我已经设法将逗号分隔的字符串转换为字符串数组,但我不确定如何将它转换为对象数组。

db.collection.updateMany(
{},
[
  {
    "$set": {
      "languages": {
        $filter: {
          input: {
            $split: [
              "$languages",
              ","
            ]
          },
          cond: {
            $gt: [
              {
                $strLenCP: "$$this"
              },
              0
            ]
          }
        }
      }
    }
  }
])
尼姆罗德总统

您所缺少的只是最后$map一步:

db.collection.update({},
[
  {
    $set: {
      languages: {
        $filter: {
          input: {$split: ["$languages", ","]},
          cond: {$gt: [{$strLenCP: "$$this"}, 0]}
        }
      }
    }
  },
  {
    $set: {
      languages: {
        $map: {
          input: "$languages",
          as: "item",
          in: {name: "$$item", active: false}
        }
      }
    }
  }
],
{multi: true})

看看它在操场上的例子是如何工作的

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章