sql >> Database >  >> NoSQL >> MongoDB

NodeJS + Mongo:invoegen indien niet bestaat, anders - update

Als u één document wilt invoegen als het niet wordt gevonden, kunt u de upsert . gebruiken optie in de update() methode:

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

Zie documenten voor de upsert gedrag.

Een voorbeeld met de $exists telefoniste.

Stel dat u 6 documenten in uw verzameling heeft:

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

en u wilt documenten vinden met een bepaald veld "a" ), kunt u find() . gebruiken methode met de $exists operator (knooppunt documenten ). Opmerking:dit zal ook documenten retourneren waarvan het veld een lege array is.

> 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. MongoDb $addFields en $match

  2. MongoDB+Azure+Android:com.mongodb.WriteConcernException err:geen hoofdcode:10058

  3. Naadloze schaal voor uw MongoDB-servers

  4. Mongo:datums in geaggregeerde zoekopdracht lijken te worden genegeerd