要素の順序に関係なく、配列に一致するドキュメントのMongoDBクエリ
これには、MongoDBで$allを使用します。 MongoDBの$all演算子は、フィールドの値が指定されたすべての要素を含む配列であるドキュメントを選択します。
まず、ドキュメントを使用してコレクションを作成しましょう-
> db.demo370.insertOne( ... { ... "Name" : "Chris", ... "details" : [ ... { ... "Subject" : "MySQL", ... "CountryName" : "US" ... }, ... { ... "Subject" : "MongoDB", ... "CountryName" : "UK" ... } ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e57e9892ae06a1609a00af0") } > db.demo370.insertOne( ... { ... "Name" : "David", ... "details" : [ ... { "Subject" : "Java", ... "CountryName" : "AUS" ... }, ... { ... "Subject" : "Spring", ... "CountryName" : "UK" ... } ... ] ... } ... ); { "acknowledged" : true, "insertedId" : ObjectId("5e57e9972ae06a1609a00af1") }
find()メソッドを使用してコレクションからすべてのドキュメントを表示する-
> db.demo370.find();
これにより、次の出力が生成されます-
{ "_id" : ObjectId("5e57e9892ae06a1609a00af0"), "Name" : "Chris", "details" : [ { "Subject" : "MySQL", "CountryName" : "US" }, { "Subject" : "MongoDB", "CountryName" : "UK" } ] } { "_id" : ObjectId("5e57e9972ae06a1609a00af1"), "Name" : "David", "details" : [ { "Subject" : "Java", "CountryName" : "AUS" }, { "Subject" : "Spring", "CountryName" : "UK" } ] }
以下は、要素の順序に関係なく、配列に一致するドキュメントのクエリです-
> db.demo370.find({ ... details: {$all: [ ... {Subject:"MySQL","CountryName" : "US"}, ... {Subject:"MongoDB", "CountryName" : "UK"} ... ]}})
これにより、次の出力が生成されます-
{ "_id" : ObjectId("5e57e9892ae06a1609a00af0"), "Name" : "Chris", "details" : [ { "Subject" : "MySQL", "CountryName" : "US" }, { "Subject" : "MongoDB", "CountryName" : "UK" } ] }
-
MongoDBに埋め込まれたドキュメントの配列をクエリし、別のドキュメントをプッシュしますか?
このために、更新と一緒に$pushを使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo573.insertOne( ... { ... '_id' :101, ... 'SearchInformation' : [ ... { ... 'Site'
-
配列フィールドを含むドキュメントに一致するMongoDBクエリ
配列フィールドを含むドキュメントを照合するには、$elemMatch演算子を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo592.insertOne( ... { ... "id":101, ... "details" : [ ... { "Name" : "Chris", "Value