Update a MongoDB document
There are two methods for updating a document
- query first
- update first
Query first document update
With this approach we first execute a query to retrieve the document we want to edit and then make the change. We use the findById
method to identify the document by its UUID and then set
to update specified properties on the document. The set
method is one of many operators that can be used to update values. For example there is also built-in operators for increment, renaming, multiplying values.
Query first is best used when you want to secure the update with some prior logic or to validate. For example you may not want to update a course if it is listed as published. You could use a query to determine the publish status and then only update the entry if it returns isPublished: false
.
async function updateCourseFromQuery(id) {
const course = await Course.findById(id);
if (!course) return;
course.set({
isPublished: true,
author: "A new author",
});
// Instead of an object, we could also set the updated properties individually
course.isPublished = true;
course.author = "Biggs Volunksire";
const result = course.save();
console.log(result);
}
Update first document update
With this approach we don’t bother with a prior query. We are confident that the update is legitimate and do not need to first determine that certain conditions are met.
To do this we directly use the update
method, not find
:
async function updateCourseFromQuery(id) {
const result = await Course.update({ _id: id });
$set: {
// Invoke the set operator
author: "Terry Nutile";
isPublished: true;
}
console.log(result);
}
This function will just return some metadata about the update. It won’t by default return the updated value. To do this use the findByIdAndUpdate()
method instead of update
:
async function updateCourseFromQuery(id) {
const course = await Course.findByIdAndUpdate(id, {
$set: { // Invoke the set operator
author: 'Terry Nutile'
isPublished: true
}, {new: true}});
console.log(result)
}
If we don’t add {new: true}
, it will return the document before the update.
Updating multiple documents at once
// Add: notes on this