MongoDBでオブジェクトの配列を検索するにはどうすればよいですか?
MongoDBでオブジェクトの配列を検索するには、$elemMatch演算子を使用できます。この演算子を使用すると、配列オブジェクトから複数のコンポーネントを検索できます。
上記の概念を理解するために、ドキュメントを使用してコレクションを作成しましょう。ドキュメントを使用してコレクションを作成するためのクエリは次のとおりです-
> db.searchArrayDemo.insertOne({"EmployeeFirstName":"Adam","EmployeeLastName":"Smith","EmployeeDateOfBirth":new ISODate("1992-01-31 13:45:10"), ... "EmployeeSkills":["Spring and Hibernate Framework","Machine Learning"], ... "EmployeeDetails":[ ... { ... "EmployeePerformanceArea":"Java", ... "Year":2001 ... }, ... { ... "EmployeePerformanceArea":"Python", ... "Year":2005 ... } ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5c77b3812386c62d05142a6a") } > db.searchArrayDemo.insertOne({"EmployeeFirstName":"Carol","EmployeeLastName":"Taylor", "EmployeeDateOfBirth":new ISODate("1993-04-21 11:10:20"), "EmployeeSkills":["C++","Cloud Computing"], "EmployeeDetails":[ { "EmployeePerformanceArea":"C++", "Year":1998 }, { "EmployeePerformanceArea":"C++ Game Developer", "Year":2007 } ] } ); { "acknowledged" : true, "insertedId" : ObjectId("5c77b58f2386c62d05142a6b") }
find()メソッドを使用して、コレクションのすべてのドキュメントを表示します。クエリは次のとおりです-
> db.searchArrayDemo.find().pretty();
以下は出力です-
{ "_id" : ObjectId("5c77b3812386c62d05142a6a"), "EmployeeFirstName" : "Adam", "EmployeeLastName" : "Smith", "EmployeeDateOfBirth" : ISODate("1992-01-31T13:45:10Z"), "EmployeeSkills" : [ "Spring and Hibernate Framework", "Machine Learning" ], "EmployeeDetails" : [ { "EmployeePerformanceArea" : "Java", "Year" : 2001 }, { "EmployeePerformanceArea" : "Python", "Year" : 2005 } ] } { "_id" : ObjectId("5c77b58f2386c62d05142a6b"), "EmployeeFirstName" : "Carol", "EmployeeLastName" : "Taylor", "EmployeeDateOfBirth" : ISODate("1993-04-21T11:10:20Z"), "EmployeeSkills" : [ "C++", "Cloud Computing" ], "EmployeeDetails" : [ { "EmployeePerformanceArea" : "C++", "Year" : 1998 }, { "EmployeePerformanceArea" : "C++ Game Developer", "Year" : 2007 } ] }
これは、MongoDBのオブジェクトの配列を検索するためのクエリです。
ケース1
指定された要素が見つかったとき。
クエリは次のとおりです-
> db.searchArrayDemo.find({EmployeeDetails:{$elemMatch:{EmployeePerformanceArea : "C++", Year : 1998}}}).pretty();
以下は出力です-
{ "_id" : ObjectId("5c77b58f2386c62d05142a6b"), "EmployeeFirstName" : "Carol", "EmployeeLastName" : "Taylor", "EmployeeDateOfBirth" : ISODate("1993-04-21T11:10:20Z"), "EmployeeSkills" : [ "C++", "Cloud Computing" ], "EmployeeDetails" : [ { "EmployeePerformanceArea" : "C++", "Year" : 1998 }, { "EmployeePerformanceArea" : "C++ Game Developer", "Year" : 2007 } ] }
ケース2
指定された要素が見つからない場合。
クエリは次のとおりです-
> db.searchArrayDemo.find({EmployeeDetails:{$elemMatch:{EmployeePerformanceArea : "C", Year : 1996}}}).pretty();
ここでは、指定された要素が見つからない場合は何も取得されません
-
MongoDBのオブジェクト内にある配列にアイテムを挿入するにはどうすればよいですか?
オブジェクト内にすでに作成されている配列にアイテムを挿入するには、MongoDB$pushを使用します。ドキュメントを使用してコレクションを作成しましょう- db.demo449.insertOne(... {... details1:{... details2:[{... _id:new ObjectId()、... Name: Chris ...}] 、... details3:[{... _id:new ObjectId()、... Name: David ...}] ...} ...} ...); {acknowledged:true 、insertedId:ObjectId( 5e
-
MongoDBのオブジェクト配列からアイテムを取得するにはどうすればよいですか?
オブジェクト配列からアイテムを取得するには、aggregate()を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo459.insertOne( ... { "_id" : 1, ... "Information" : [ ... { ... "Name" : "Chris", ... "_id" : new ObjectId(), ... &n