MongoDB
 sql >> Baza danych >  >> NoSQL >> MongoDB

NodeJS + Mongo:Wstaw, jeśli nie istnieje, w przeciwnym razie - zaktualizuj

Jeśli chcesz wstawić jeden dokument, jeśli nie zostanie znaleziony, możesz użyć upsert opcja w update() metoda:

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

Zobacz dokumentację upsert zachowanie.

Przykład z $exists operatora.

Załóżmy, że masz w swojej kolekcji 6 dokumentów:

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

i chcesz znaleźć dokumenty, które mają określone pole "a" ), możesz użyć find() metoda z $exists operator (węzeł dokumenty ). Uwaga:spowoduje to również zwrócenie dokumentów, których pole jest pustą tablicą.

> 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. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. 2 sposoby na odkrycie indeksu w MongoDB

  2. Dokument podrzędny dotyczący wypełnienia mangusty

  3. Jaka jest różnica między findOneAndUpdate a findOneAndReplace?

  4. Birt mongodb param

  5. Używanie sparse:true nadal pojawia się MongoError:błąd duplikatu klucza E11000