sql >> Databáze >  >> NoSQL >> MongoDB

NodeJS + Mongo:Vložit, pokud neexistuje, jinak - aktualizovat

Pokud chcete vložit jeden dokument, pokud není nalezen, můžete použít upsert možnost v update() metoda:

collection.update(_query_, _update_, { upsert: true });

Viz dokumenty pro upsert chování.

Příklad s $exists operátor.

Řekněme, že máte ve sbírce 6 dokumentů:

> 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 }

a chcete najít dokumenty, které mají určité pole "a" ), můžete použít find() metoda s $exists operátor (uzel dokumenty ). Poznámka:Toto vrátí také dokumenty, jejichž pole je prázdné pole.

> 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 ] }



  1. Upravte a přehrajte oplog MongoDB

  2. Proč MongoDB již neumožňuje použití $set a $unset s prázdným dokumentem?

  3. Připojení k MongoDB ReplicaSet na Kubernetes

  4. pomocí module.exports neobvyklým způsobem