MongoDBコレクション内のIDを介して配列エントリを検索し、更新を実行します
idを介して配列を検索するには、positional$演算子を使用します。更新には、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" } ] }
以下は、MongoDBコレクション内のIDを介して配列エントリを検索するためのクエリです-
> 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" } ] }
-
_idのMongoDBコレクションを更新していますか?
_idを更新するには、MongoDBで$setを使用します。ドキュメントを使用してコレクションを作成しましょう- db.demo741.insertOne({SubjectName:"MySQL"}); { "acknowledged" : true, "insertedId" : ObjectId("5ead718657bb72a10bcf0672") } > db.demo741.insertOne({SubjectName:"C"}
-
MongoDBの配列に重複がないか確認しますか?
配列内の重複をチェックするには、MongoDBでaggregate()を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo756.insertOne({"SubjectName":["MySQL","MongoDB","Java"]}); { "acknowledged" : true, "insertedId" : ObjectId("5eb01e0d5637cd592b2