I have the following code:
connection((db) => {
db.collection('orders')
.updateOne(
{ "_id": req.body._id}, // Filter
{"name": req.body.name} // Update
)
.then((obj) => {
console.log('Updated - ' + obj);
res.redirect('orders')
})
.catch((err) => {
console.log('Error: ' + err);
})
})
I want to change the name in the order but it doesn't update it. The result in the console is
Updated - {"n":0,"nModified":0,"ok":1}
I tried to read the documentation but it's horrific
EDIT: {$set: {"name": req.body.name}},
didn't work as well
EDIT 2: The passed ID matches the _id in the database. Could it be a problem that I'm querying for plain text ID while in the database it is referred to as "ObjectId('5a42ja...')"
Tough @Spraw's answer is right for some cases, but sometimes it doesn't work. I think the convenient answer is
updateOne({_id: new ObjectID(req.body._id)}, {$set: {"name": req.body.name}}, callback)
.the
_id
inmongodb
is aBSON
object and should be instantiated.Use
{$set: {"name": req.body.name}}
(as Sparw mentioned) to update the the properties you want in the document. Also, if the id that you pass as a parameter does not exists in the collection (and you want to create one with the same id) you can pass as a third parameter{upsert: true}
to create one.In your example:
The correct syntax is:
Too late but for newbies or students learning nodejs with mongodb. instead of
updateOne
method, just use theupdate
method.Maybe you should use "$set" in your update query like this :
More information in documentation
EDIT
If it doesn't work, this is probably because there is no match with your filter.
Maybe you should try to match with an ObjectId like this :
Hope it helps.
For me, I have to delete the "_id"/id field before passing the object in the update.
Or it will say that the field is invalid.
Obviously, updated the key while you're using it as a reference isn't the best thing to do.