MongoDB 按兩個欄位求和排序?
若要按照兩個欄位求和進行排序,可以使用集合框架。我們首先建立一個包含文件的集合
> db.orderByTwoFieldsDemo.insertOne({"Value1":10,"Value2":35});
{
"acknowledged" : true,
"insertedId" : ObjectId("5ca285576304881c5ce84baa")
}
> db.orderByTwoFieldsDemo.insertOne({"Value1":12,"Value2":5});
{
"acknowledged" : true,
"insertedId" : ObjectId("5ca2855f6304881c5ce84bab")
}
> db.orderByTwoFieldsDemo.insertOne({"Value1":55,"Value2":65});
{
"acknowledged" : true,
"insertedId" : ObjectId("5ca285686304881c5ce84bac")
}以下是使用 find() 方法從集合中顯示所有文件的查詢
> db.orderByTwoFieldsDemo.find().pretty();
這將生成以下輸出
{
"_id" : ObjectId("5ca285576304881c5ce84baa"),
"Value1" : 10,
"Value2" : 35
}
{
"_id" : ObjectId("5ca2855f6304881c5ce84bab"),
"Value1" : 12,
"Value2" : 5
}
{
"_id" : ObjectId("5ca285686304881c5ce84bac"),
"Value1" : 55,
"Value2" : 65
}案例 1: 以下是按兩個欄位求和並按升序獲取結果的查詢
> db.orderByTwoFieldsDemo.aggregate(
... [
... {$project:{Value1:1, Value2:1, orderBySumValue:{$add: ["$Value1", "$Value2"]}}},
... {$sort:{orderBySumValue:1}}]
... );這將生成以下輸出
{ "_id" : ObjectId("5ca2855f6304881c5ce84bab"), "Value1" : 12, "Value2" : 5,
"orderBySumValue" : 17 }
{ "_id" : ObjectId("5ca285576304881c5ce84baa"), "Value1" : 10, "Value2" : 35,
"orderBySumValue" : 45 }
{ "_id" : ObjectId("5ca285686304881c5ce84bac"), "Value1" : 55, "Value2" : 65,
"orderBySumValue" : 120 }案例 2: 以下是按兩個欄位求和並按降序獲取結果的查詢
> db.orderByTwoFieldsDemo.aggregate( [ {$project:{Value1:1, Value2:1,
orderBySumValue:{$add: ["$Value1", "$Value2"]}}}, {$sort:{orderBySumValue:-1}}] );這將生成以下輸出
{ "_id" : ObjectId("5ca285686304881c5ce84bac"), "Value1" : 55, "Value2" : 65,
"orderBySumValue" : 120 }
{ "_id" : ObjectId("5ca285576304881c5ce84baa"), "Value1" : 10, "Value2" : 35,
"orderBySumValue" : 45 }
{ "_id" : ObjectId("5ca2855f6304881c5ce84bab"), "Value1" : 12, "Value2" : 5,
"orderBySumValue" : 17 }
廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP