MongoDB
 Computer >> コンピューター >  >> プログラミング >> MongoDB

どのような種類のMongoDBクエリが、配列内で同じ値を複数回検出しますか?


同じ値を複数回検索するには、MongoDBの$whereを使用します。ドキュメントを使用してコレクションを作成しましょう-

> db.demo188.insertOne(
...   {
...      "ListOfData":[
...         {"Data": 100},
...         {"Data": 200},
...         {"Data": 100}
...      ]
...   }
...);
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e3ad1c203d395bdc21346bd")
}
> db.demo188.insertOne(
...   {
...      "ListOfData":[
...         {"Data": 100},
...         {"Data": 200},
...         {"Data": 300}
...   }
...);
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e3ad1c203d395bdc21346be")
}

find()メソッドを使用してコレクションからすべてのドキュメントを表示する-

> db.demo188.find();

これにより、次の出力が生成されます-

{ "_id" : ObjectId("5e3ad1c203d395bdc21346bd"), "ListOfData" : [ { "Data" : 100 }, { "Data" : 200 }, { "Data" : 100 } ] }
{ "_id" : ObjectId("5e3ad1c203d395bdc21346be"), "ListOfData" : [ { "Data" : 100 }, { "Data" : 200 }, { "Data" : 300 } ] }

以下は、配列内で同じ値を複数回検索するためのクエリです-

> db.demo188.find({
...   "$where": function() {
...      return this.ListOfData.filter(function(d) {
...         return d.Data == 100;
...      }).length > 1;
...   }
...})

これにより、次の出力が生成されます-

{ "_id" : ObjectId("5e3ad1c203d395bdc21346bd"), "ListOfData" : [ { "Data" : 100 }, { "Data" : 200 }, { "Data" : 100 } ] }

  1. idがドキュメントフィールドの配列値と等しい場合に除外するMongoDBクエリ

    このために、$inと一緒に$notを使用します。ドキュメントを使用してコレクションを作成しましょう- [    {       id: "101",       subjectid: [          "102"       ]    },    {       id: "102",   &nb

  2. MongoDBで配列をクエリして、特定の値をフェッチします

    配列から特定の値をフェッチするには、$ projectとともにaggregate()を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo761.insertOne( ...    { ...       "details": [ ...          { ...             "student": { ...     &nb