Я не могу найти, как добавить новое поле в существующую коллекцию.
Я знаю, как обновлять существующее поле коллекции, но не как добавить новое несуществующее поле в коллекции. Кроме того, как мне добавить новые поля во все документы коллекции?
Я не могу найти, как добавить новое поле в существующую коллекцию.
Я знаю, как обновлять существующее поле коллекции, но не как добавить новое несуществующее поле в коллекции. Кроме того, как мне добавить новые поля во все документы коллекции?
Аналогично обновлению существующего поля коллекции $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})