使用 MongoDB 更新操作將欄位轉換為陣列?


要將欄位轉換為陣列,請使用 $set 運算子。我們先使用文件建立一個集合 −

> db.convertAFieldToAnArrayDemo.insertOne({"StudentSubject":"MongoDB"});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5ce92d7778f00858fb12e91d")
}

以下查詢顯示瞭如何使用 find() 方法顯示集合中的所有文件 −

> db.convertAFieldToAnArrayDemo.find();

這將生成以下輸出 −

{ "_id" : ObjectId("5ce92d7778f00858fb12e91d"), "StudentSubject" : "MongoDB" }

以下查詢演示瞭如何使用 $set 與更新操作將欄位轉換為陣列:−

> db.convertAFieldToAnArrayDemo.find().forEach(function(myDocument) {
   db.convertAFieldToAnArrayDemo.update(
      { _id: myDocument._id },
      { "$set": { "StudentSubject": [myDocument.StudentSubject] } }
   );
})

讓我們再次檢查該文件 −

> db.convertAFieldToAnArrayDemo.find();

這將生成以下輸出 −

{ "_id" : ObjectId("5ce92d7778f00858fb12e91d"), "StudentSubject" : [ "MongoDB" ] }

更新於:2019 年 7 月 30 日

1000+ 次瀏覽

啟動職業生涯

透過完成課程獲得認證

開始
廣告
© . All rights reserved.