MongoDB
 sql >> Base de données >  >> NoSQL >> MongoDB

NodeJS + Mongo :Insérer s'il n'existe pas, sinon - mettre à jour

Si vous souhaitez insérer un document s'il n'est pas trouvé, vous pouvez utiliser le upsert option dans update() méthode :

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

Voir les documents pour le upsert comportement.

Un exemple avec le $exists opérateur.

Disons que vous avez 6 documents dans votre collection :

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

et vous voulez trouver des documents qui ont un certain champ "a" ), vous pouvez utiliser find() méthode avec le $exists opérateur (nœud documentation ). Remarque :cela renverra également les documents dont le champ est un tableau vide.

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