【发布时间】:2013-03-02 22:08:34
【问题描述】:
我有一系列簿记条目,如下所示:
{
_id: 5141aff1a1d24c991a000002,
date: 2012-02-23 00:00:00 UTC,
details: "sdfd",
value: 250,
clinic_id: "513e2227a1d24ceab3000001"
}
我想获取每月贷方和借方总额的报告。像这样:
[
{"credit"=> -229, "debit" => 0 "month"=>1},
{"credit"=> -229, "debit" => 0 "month"=>2},
{"credit"=> -229, "debit" => 0 "month"=>3},
{"credit"=> -229, "debit" => 0 "month"=>4},
{"credit"=> -229, "debit" => 0 "month"=>5},
{"credit"=> -229, "debit" => 0 "month"=>6},
{"credit"=> -229, "debit" => 0 "month"=>7},
{"credit"=> 0, "debit" => 300 "month"=>8},
{"credit"=> 0, "debit" => 300 "month"=>9},
{"credit"=> 0, "debit" => 300 "month"=>10},
{"credit"=> 0, "debit" => 300 "month"=>11},
{"credit"=> 0, "debit" => 300 "month"=>12}
]
为了做到这一点,我打算使用聚合框架。
- 当 $value credit?
- 当 $value >= 0 时,如何将 $value 分配给
debit? - 如何分组?
我有这个:
BookKeepingEntry.collection.aggregate(
[ { "$match" => { "clinic_id" => self.clinic.id } },
{ "$project" =>
{
"credit" => { what here? },
"debit" => { What here?}
"month" => { "$month" => "$date" }
}
},
{ "$group" => {} }
{ "$sort" => { "month" => 1 } }
]
)
【问题讨论】:
-
看看
$cond投影运算符。 -
我问过一个类似的问题,@JohnnyHK 已经回答了 :) stackoverflow.com/questions/14102596/conditional-sum-in-mongodb 请参阅下面的答案。