通过 MongoDB 集合中的 ID 搜索数组条目并执行更新
要通过 id 搜索数组,请使用位置 $ 运算符。对于更新,请在 MongoDB 中使用 UPDATE。让我们创建一个包含以下文档的集合 -
> db.demo49.insertOne( ... { ... ... "Name": "David", ... "Details": [ ... { ... "_id": "D1234", ... "Subject":"MySQL" ... }, ... { ... "_id": "E234", ... "Subject":"Java" ... }, ... { ... "_id": "F456", ... "Subject":"Python" ... } ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e270a77cfb11e5c34d89902") }
在 find() 方法的帮助下显示某个集合中的所有文档 -
> db.demo49.find();
将产生以下输出 -
{ "_id" : ObjectId("5e270a77cfb11e5c34d89902"), "Name" : "David", "Details" : [ { "_id" : "D1234", "Subject" : "MySQL" }, { "_id" : "E234", "Subject" : "Java" }, { "_id" : "F456", "Subject" : "Python" } ] }
以下是通过 id 在 MongoDB 集合中搜索数组条目的查询 -
> db.demo49.update( {"Details._id":"E234"}, ... {$set:{"Details.$.Subject":"MongoDB"}}, false, true ) WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
在 find() 方法的帮助下显示某个集合中的所有文档 -
> db.demo49.find();
将产生以下输出 -
{ "_id" : ObjectId("5e270a77cfb11e5c34d89902"), "Name" : "David", "Details" : [ { "_id" : "D1234", "Subject" : "MySQL" }, { "_id" : "E234", "Subject" : "MongoDB" }, { "_id" : "F456", "Subject" : "Python" } ] }
广告