Hãy thử nó với khung tổng hợp sử dụng $ đối sánh và $ group toán tử, tức là một cái gì đó tương tự như thế này
db.tickets.aggregate([
{ $match: { time: {$gte: a, $lte: tomorrow} } },
{ $group: { _id: null, amount: { $sum: "$amount" } } }
])
ví dụ với dữ liệu thử nghiệm như thế này
/* 1 */
{
"_id" : ObjectId("57e0ed40828913a99c2ceb46"),
"time" : 20,
"amount" : 40
}
/* 2 */
{
"_id" : ObjectId("57e0ed40828913a99c2ceb47"),
"time" : 40,
"amount" : 20
}
/* 3 */
{
"_id" : ObjectId("57e0ed40828913a99c2ceb48"),
"time" : 50,
"amount" : 10
}
/* 4 */
{
"_id" : ObjectId("57e0ed40828913a99c2ceb49"),
"time" : 10,
"amount" : 5
}
một đường dẫn (với phạm vi thời gian giả) như sau
db.tickets.aggregate([
{ $match: { time: {$gte: 20, $lte: 40} } },
{ $group: { _id: null, amount: { $sum: "$amount" } } }
])
sẽ cho bạn một kết quả như thế này
/* 1 */
{
"_id" : null,
"amount" : 60
}