MongoDB
 sql >> Datenbank >  >> NoSQL >> MongoDB

NodeJS + Mongo:Einfügen, wenn nicht vorhanden, sonst - aktualisieren

Wenn Sie ein Dokument einfügen möchten, wenn es nicht gefunden wird, können Sie den upsert verwenden Option im update() Methode:

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

Siehe Dokumentation für den Upsert Verhalten.

Ein Beispiel mit dem $exists Betreiber.

Angenommen, Sie haben 6 Dokumente in Ihrer Sammlung:

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

und Sie möchten Dokumente finden, die ein bestimmtes Feld "a" haben ), können Sie find() verwenden -Methode mit $exists Operator (node Dokumente ). Hinweis:Dies gibt auch Dokumente zurück, deren Feld ein leeres Array ist.

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