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

コレクション内のグループごとに最大属性を持つMongoDBドキュメントを取得しますか?


$sort演算子と$groupステートメントを使用して、コレクション内のグループごとに最大属性を持つドキュメントを取得できます。

概念をさらに理解するために、ドキュメントを使用してコレクションを作成しましょう。ドキュメントを使用してコレクションを作成するためのクエリは次のとおりです-

> db.maxAttributePerGroup.insertOne({"StudentFirstName":"John","StudentLastName":"Smith
   ","StudentAge":29,"StudentId":10});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c76ee341e9c5dd6f1f78277")
}
> db.maxAttributePerGroup.insertOne({"StudentFirstName":"Carol","StudentLastName":"Taylo
   r","StudentAge":19,"StudentId":10});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c76ee4e1e9c5dd6f1f78278")
}
> db.maxAttributePerGroup.insertOne({"StudentFirstName":"Adam","StudentLastName":"Smit
   h","StudentAge":34,"StudentId":20});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c76ee631e9c5dd6f1f78279")
}
> db.maxAttributePerGroup.insertOne({"StudentFirstName":"Bob","StudentLastName":"Taylor"
   ,"StudentAge":58,"StudentId":20});
{
   "acknowledged" : true,
   "insertedId" : ObjectId("5c76ee791e9c5dd6f1f7827a")
}

find()メソッドを使用して、コレクションのすべてのドキュメントを表示します。クエリは次のとおりです-

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

出力

{
   "_id" : ObjectId("5c76ee341e9c5dd6f1f78277"),
   "StudentFirstName" : "John",
   "StudentLastName" : "Smith",
   "StudentAge" : 29,
   "StudentId" : 10
}
{
   "_id" : ObjectId("5c76ee4e1e9c5dd6f1f78278"),
   "StudentFirstName" : "Carol",
   "StudentLastName" : "Taylor",
   "StudentAge" : 19,
   "StudentId" : 10
}
{
   "_id" : ObjectId("5c76ee631e9c5dd6f1f78279"),
   "StudentFirstName" : "Adam",
   "StudentLastName" : "Smith",
   "StudentAge" : 34,
   "StudentId" : 20
}
{
   "_id" : ObjectId("5c76ee791e9c5dd6f1f7827a"),
   "StudentFirstName" : "Bob",
   "StudentLastName" : "Taylor",
   "StudentAge" : 58,
   "StudentId" : 20
}

これは、コレクション内のグループごとに最大属性を持つドキュメントを取得するためのクエリです-

> db.maxAttributePerGroup.aggregate([
   ... {"$sort":{"StudentId":1,"StudentAge":-1}},
   ... {$group:{
   ... "_id":"$StudentId",
   ... "StudentAge":{"$first":"$StudentAge"},
   ... "StudentFirstName":{"$first":"$StudentFirstName"},
   ... "StudentLastName":{"$first":"$StudentLastName"}
... }} ]).pretty();

出力

{
   "_id" : 20,
   "StudentAge" : 58,
   "StudentFirstName" : "Bob",
   "StudentLastName" : "Taylor"
}
{
   "_id" : 10,
   "StudentAge" : 29,
   "StudentFirstName" : "John",
   "StudentLastName" : "Smith"
}

  1. $または?で設定された複数の条件を持つドキュメントを取得するためのMongoDBクエリ

    ドキュメントを使用してコレクションを作成しましょう- > db.demo711.insertOne({Name:"John","Marks":75,Age:21,status:"Active"}); {    "acknowledged" : true,    "insertedId" : ObjectId("5ea85c215d33e20ed1097b7e") } > db.demo711.insertOne({Name:

  2. コレクション内のドキュメントの各フィールドを数式で更新するMongoDBクエリ?

    コレクション内のドキュメントの各フィールドを数式で更新するには、MongoDB update()を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo749.insertOne({"details":[{"id":1,a:10},{"id":2,a:5},{"id":3,a:20}]}); {    "acknowledged" : true,    "insertedId" : ObjectId(