Добавить новое поле в коллекцию в MongoDB

Я не могу найти, как добавить новое поле в существующую коллекцию.

Я знаю, как обновлять существующее поле коллекции, но не как добавить новое несуществующее поле в коллекции. Кроме того, как мне добавить новые поля во все документы коллекции?

Ответ 1

Аналогично обновлению существующего поля коллекции $set добавит новые поля, если указанное поле не существует.

Проверьте образец

> db.foo.find()
> db.foo.insert({"test":"a"})
> db.foo.find()
{ "_id" : ObjectId("4e93037bbf6f1dd3a0a9541a"), "test" : "a" }
> item = db.foo.findOne()
{ "_id" : ObjectId("4e93037bbf6f1dd3a0a9541a"), "test" : "a" }
> db.foo.update({"_id" :ObjectId("4e93037bbf6f1dd3a0a9541a") },{$set : {"new_field":1}})
> db.foo.find()
{ "_id" : ObjectId("4e93037bbf6f1dd3a0a9541a"), "new_field" : 1, "test" : "a" }

EDIT:

Если вы хотите добавить new_field ко всей своей коллекции, вам нужно использовать пустой селектор и установить для параметра multi flag значение true (последний параметр) для обновления всех документов

db.your_collection.update({}, {$ set: { "new_field": 1}}, false, true)

EDIT:

В приведенном выше примере последние 2 поля false, true определяют флаги upsert и multi.

Upsert: Если установлено значение true, создается новый документ, если документ не соответствует критериям запроса.

Multi: Если установлено значение true, обновляется несколько документов, соответствующих критериям запроса. Если установлено значение false, обновляется один документ.

Это для Mongo versions до 2.2. Для последних версий запрос немного изменяется

db.your_collection.update({},
                          {$set : {"new_field":1}},
                          {upsert:false,
                          multi:true})