簡體   English   中英

如何將數據字段從一個集合中的所有文檔移到另一集合中的新文檔中?

[英]How do I move fields of data from all documents in one collection into new documents of a different collection?

我的處境 :我創建了Mongo(貓鼬),Express和Node應用程序,現在我正在構建其他功能,我意識到我的模型無法處理這些新功能,因此我建立了一個可以證明未來的新模型,但是我需要將某些數據字段從舊模型User移到新模型List中。

將文檔數據從一個文檔集中的所有特定字段移動到新文檔集中的新文檔中的最佳方法是什么? 我可以使用JavaScript創建腳本並在服務器或數據庫上運行它嗎?

如果可能的話,我不想破壞用戶的體驗。 另外,我知道有db.collection.update方法,但是我需要一次移動所有這些數據,而不是每當我在應用程序中運行該方法時。

您可以通過多種方式編寫腳本,但是最簡單的方法是:

  1. 在管道的結尾使用$out階段的aggregate從原始文檔填充新的集合。 在管道中使用$project階段根據需要構造輸出文檔。
  2. 在原始集合上使用updateMany可以使用$unset運算符刪除“已移動”字段。

根據系統的具體情況,在執行此操作時,您可能仍需要使用戶脫機。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM