node.js - cómo - nodejs mongodb update document
NodeJS+Mongo: Insertar si no existe; de lo contrario, actualizar (1)
Tengo un objeto en mi colección mongodb. Su esquema es:
{
"instruments": ["A", "B", "C"],
"_id": {
"$oid": "508510cd6461cc5f61000001"
}
}
Mi colección puede tener dicho objeto, pero puede que no. Necesito verificar si el objeto con los "instrumentos" clave existe ( por favor, no, no sé qué valor tiene el "instrumento" en este momento, puede contener cualquier valor o una matriz ), y si existe - realizar la actualización, de lo contrario - inserta un nuevo valor. ¿Cómo puedo hacer esto?
collection.find( { "instruments" : { $exists : true } }, function(err, object){
if (object) {
//update
} else {
//insert
}
});
no funciona ((
Si desea insertar un documento si no se encuentra, puede usar la opción de upsert
en la función de update()
:
collection.update(selector, document, { upsert: true });
Ejemplo de $exists
:
Digamos que tienes estos 6 documentos en tu colección
> 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 }
Si desea buscar documentos que tengan un determinado campo, puede usar find()
con el operador $ exists ( documentos de nodo ). Esto también devolverá documentos que contienen campos y un conjunto vacío.
> 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 ] }