Подтвердить что ты не робот

NodeJS + Mongo: Вставить, если не существует, в противном случае - обновить

У меня есть объект в моей коллекции mongodb. Его схема:

{
    "instruments": ["A", "B", "C"],
    "_id": {
        "$oid": "508510cd6461cc5f61000001"
    }
}

Моя коллекция может иметь такой объект, но может и не быть. Мне нужно проверить, существует ли объект с ключевыми "инструментами" (, пожалуйста, notе, я не знаю, какое значение "инструмент" в данный момент может содержать любое значение или массив), и если существует - выполнить обновление, иначе - вставить новое значение. Как я могу это сделать?

collection.find( {  "instruments" : { $exists : true } }, function(err, object){
    if (object) {
        //update
    } else {
        //insert
    }
});

не работает ((

4b9b3361

Ответ 1

Если вы хотите вставить документ, если он не найден, вы можете использовать опцию upsert в функции update():

collection.update(selector, document, { upsert: true });

Пример $exists:

Скажем, у вас есть эти 6 документов в вашей коллекции

> db.test.find()
{ "_id": ObjectId("5495aebff83774152e9ea6b2"), "a": 1 }
{ "_id": ObjectId("5495aec2f83774152e9ea6b3"), "a": [ ] }
{ "_id": ObjectId("5495aec7f83774152e9ea6b4"), "a": [ "b" ] }
{ "_id": ObjectId("5495aecdf83774152e9ea6b5"), "a": [ null ] }
{ "_id": ObjectId("5495aed5f83774152e9ea6b7"), "a": [ 0 ] }
{ "_id": ObjectId("5495af60f83774152e9ea6b9"), "b": 2 }

Если вы хотите найти документы, имеющие определенное поле, вы можете использовать find() с оператором $exists (node docs). Это также вернет документы, содержащие поля пустого массива.

> db.test.find( { a: { $exists: true } } )
{ "_id": ObjectId("5495aebff83774152e9ea6b2"), "a": 1 }
{ "_id": ObjectId("5495aec2f83774152e9ea6b3"), "a": [ ] }
{ "_id": ObjectId("5495aec7f83774152e9ea6b4"), "a": [ "b" ] }
{ "_id": ObjectId("5495aecdf83774152e9ea6b5"), "a": [ null ] }
{ "_id": ObjectId("5495aed5f83774152e9ea6b7"), "a": [ 0 ] }