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

サブドキュメント配列のn番目の要素(変数インデックス)に対するMongoDBクエリ


これには、$letを$exprと一緒に使用します。ここで、$letは一時変数を定義するために使用されます。 $ exprは、集計式に使用されます。ドキュメントを使用してコレクションを作成しましょう-

> db.demo72.insertOne(
... {
...    StudentDetails:[
...       {
...          Name: "Chris",
...          Age: 21
...       },
...       {
...          Name: "David",
...          Age: 23
...       },
...       {
...          Name: "Bob",
...          Age: 20
...       },
...    ]
... }
... );
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5e29b4ad71bf0181ecc42269")
}

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

> db.demo72.find().pretty();

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

{
   "_id" : ObjectId("5e29b4ad71bf0181ecc42269"),
   "StudentDetails" : [
      {
         "Name" : "Chris",
         "Age" : 21
      },
      {
         "Name" : "David",
         "Age" : 23
      },
      {
         "Name" : "Bob",
         "Age" : 20
      }
   ]
}

以下は、サブドキュメント配列のn番目の要素(変数インデックス)に対するクエリです-

> db.demo72.find({
... $expr: {
...    $let: {
...       vars: { fst: { $arrayElemAt: [ "$StudentDetails", 1 ] } },
...       in: { $eq: [ "$$fst.Name", "David" ] }
...       }
...    }
... })

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

{
   "_id" : ObjectId("5e29b4ad71bf0181ecc42269"),
   "StudentDetails" : [
      {
         "Name" : "Chris",
         "Age" : 21
      },
      {
         "Name" : "David",
         "Age" : 23
      },
      {
         "Name" : "Bob",
         "Age" : 20
      }
   ]
}

  1. 配列の1つの要素のみをスライスするMongoDBクエリ

    配列の1つの要素のみをスライスするには、MongoDBで$sliceを使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo579.insertOne( ...    { ...       "_id" : 101, ...       "details" : { "FirstName" : "John" }, ...       "Marks" :

  2. 配列要素の集計で平均を取得するMongoDBクエリ?

    配列要素の平均を取得するには、$avgを使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo584.insertOne({"Marks":[75,50,85,60,80]});{    "acknowledged" : true,    "insertedId" : ObjectId("5e91d827fd2d90c177b5bcc2") } find()メソッドを使用してコレクションからすべてのドキュメントを表示する- > db