MongoDBで配列交差のデータを取得するにはどうすればよいですか?
MongoDBでの配列の相互作用については、aggregate()で$setIntersectionを使用します。ドキュメントを使用してコレクションを作成しましょう-
> db.demo625.insertOne( ... { ... Name: "John", ... Marks: [56,98,60] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e9ab8e16c954c74be91e6aa") } > db.demo625.insertOne( ... { ... Name: "John", ... Marks: [110,56,72] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e9ab8e26c954c74be91e6ab") } > db.demo625.insertOne( ... { ... Name: "Chris", ... Marks: [90,91] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e9ab8e26c954c74be91e6ac") } > db.demo625.insertOne( ... { ... Name: "Robert", ... Marks: [60,75] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e9ab8e26c954c74be91e6ad") }
find()メソッドを使用してコレクションからすべてのドキュメントを表示する-
> db.demo625.find();
これにより、次の出力が生成されます-
{ "_id" : ObjectId("5e9ab8e16c954c74be91e6aa"), "Name" : "John", "Marks" : [ 56, 98, 60 ] } { "_id" : ObjectId("5e9ab8e26c954c74be91e6ab"), "Name" : "John", "Marks" : [ 110, 56, 72 ] } { "_id" : ObjectId("5e9ab8e26c954c74be91e6ac"), "Name" : "Chris", "Marks" : [ 90, 91 ] } { "_id" : ObjectId("5e9ab8e26c954c74be91e6ad"), "Name" : "Robert", "Marks" : [ 60, 75 ] }
以下は、MongoDBの配列交差のデータを取得するためのクエリです-
> db.demo625.aggregate([ ... ... ... { "$project": { ... "Name": 1, ... "Marks": { ... "$setIntersection": [ "$Marks", [56,98,60] ] ... } ... }} ... ])
これにより、次の出力が生成されます-
{ "_id" : ObjectId("5e9ab8e16c954c74be91e6aa"), "Name" : "John", "Marks" : [ 56, 60, 98 ] } { "_id" : ObjectId("5e9ab8e26c954c74be91e6ab"), "Name" : "John", "Marks" : [ 56 ] } { "_id" : ObjectId("5e9ab8e26c954c74be91e6ac"), "Name" : "Chris", "Marks" : [ ] } { "_id" : ObjectId("5e9ab8e26c954c74be91e6ad"), "Name" : "Robert", "Marks" : [ 60 ] }
-
MongoDBの配列に追加するにはどうすればよいですか?
MongoDBの配列に追加するには、$concatArraysを使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo435.insertOne({"FirstName":["Chris"],"LastName":["Brown"]} ); { "acknowledged" : true, "insertedId" : ObjectId("5e7719b1bbc41e36cc3c
-
MongoDBのオブジェクト配列からアイテムを取得するにはどうすればよいですか?
オブジェクト配列からアイテムを取得するには、aggregate()を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo459.insertOne( ... { "_id" : 1, ... "Information" : [ ... { ... "Name" : "Chris", ... "_id" : new ObjectId(), ... &n