特定のフィールドを合計するMongoDBクエリ
特定のフィールドを合計するには、$sumとともにaggregateを使用します。まず、ドキュメントを使用してコレクションを作成しましょう-
> db.getSumOfFieldsDemo.insertOne({"Customer_Id":101,"Price":50,"Status":"Active"});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e06cec29e4dae213890ac55")
}
> db.getSumOfFieldsDemo.insertOne({"Customer_Id":102,"Price":200,"Status":"Inactive"});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e06ced19e4dae213890ac56")
}
> db.getSumOfFieldsDemo.insertOne({"Customer_Id":101,"Price":3000,"Status":"Active"});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e06cedd9e4dae213890ac57")
}
> db.getSumOfFieldsDemo.insertOne({"Customer_Id":103,"Price":400,"Status":"Active"});
{
"acknowledged" : true,
"insertedId" : ObjectId("5e06cee79e4dae213890ac58")
} 以下は、find()メソッドを使用してコレクションからすべてのドキュメントを表示するためのクエリです-
> db.getSumOfFieldsDemo.find().pretty();
これにより、次の出力が生成されます-
{
"_id" : ObjectId("5e06cec29e4dae213890ac55"),
"Customer_Id" : 101,
"Price" : 50,
"Status" : "Active"
}
{
"_id" : ObjectId("5e06ced19e4dae213890ac56"),
"Customer_Id" : 102,
"Price" : 200,
"Status" : "Inactive"
}
{
"_id" : ObjectId("5e06cedd9e4dae213890ac57"),
"Customer_Id" : 101,
"Price" : 3000,
"Status" : "Active"
}
{
"_id" : ObjectId("5e06cee79e4dae213890ac58"),
"Customer_Id" : 103,
"Price" : 400,
"Status" : "Active"
} 以下は、ACTIVEステータスに基づいて特定のフィールドを合計するためのクエリです-
> db.getSumOfFieldsDemo.aggregate([ { $match: { Status: "Active" } }, { $group: { _id: "$Customer_Id", TotalSum: { $sum: "$Price" } } } ]); これにより、次の出力が生成されます-
{ "_id" : 103, "TotalSum" : 400 }
{ "_id" : 101, "TotalSum" : 3050 } -
MongoDBクエリで特定の列を選択するにはどうすればよいですか?
特定の列を選択するには、残りの列を無視できます。つまり、それらの列を非表示にするには、0に設定します。最初にドキュメントを含むコレクションを作成しましょう- > db.demo415.insertOne({"ClientName":"Robert","ClientCountryName":"US"}); { "acknowledged" : true, "insertedId" : ObjectId("5e7
-
MongoDBで配列をクエリして、特定の値をフェッチします
配列から特定の値をフェッチするには、$ projectとともにaggregate()を使用します。ドキュメントを使用してコレクションを作成しましょう- > db.demo761.insertOne( ... { ... "details": [ ... { ... "student": { ... &nb