MongoDB
 sql >> Base de Dados >  >> NoSQL >> MongoDB

NodeJS + Mongo:Inserir se não existir, caso contrário - atualizar


Se você quiser inserir um documento se não for encontrado, você pode usar o upsert opção no update() método:
collection.update(_query_, _update_, { upsert: true });

Consulte a documentação do upsert comportamento.

Um exemplo com o $exists operador.

Digamos que você tenha 6 documentos em sua coleção:
> 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 }

e você deseja encontrar documentos que tenham um determinado campo "a" ), você pode usar find() método com o $exists operador (nó documentos ). Nota:isso também retornará documentos cujo campo é um array vazio.
> 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 ] }