我有一个名为posts
的SQLite表。一个例子如下所示。我想计算每月的收入和支出。
accId date text amount balance ---------- ---------- ------------------------ ---------- ---------- 1 2008-03-25 Ex1 -64.9 3747.56 1 2008-03-25 Shop2 -91.85 3655.71 1 2008-03-26 Benny's -100.0 3555.71
对于收入,我有这个问题:
SELECT SUBSTR(date, 0,7) "month", total(amount) "income" FROM posts WHERE amount > 0 GROUP BY month ORDER BY date;
工作正常:
month income ---------- ---------- 2007-05 4877.0 2007-06 8750.5 2007-07 8471.0 2007-08 5503.0
现在我需要费用,我可以因为只重复条件amount < 0
的第一个语句,但我想知道是否有一种优雅的方法可以在一个查询中同时获得收入和费用?
答案 0 :(得分:6)
尝试这样的事情
select substr(date, 0,7) "Month",
total(case when a > 0 then a else 0 end) "Income",
total(case when a < 0 then a else 0 end) "Expenses"
from posts
group by month
答案 1 :(得分:2)
不确定SQL Lite是否支持CASE语句,但如果确实如此,您可以执行类似的操作。
SELECT SUBSTR(date, 0,7) "month"
, total(CASE WHEN Amount > 0 THEN Amount ELSE 0 END) "income"
, -1 * total(CASE WHEN Amount < 0 THEN Amount ELSE 0 END) "expenses"
FROM posts
GROUP BY month
ORDER BY date;
答案 2 :(得分:2)
查看UNION语句(链接底部)。这将允许您组合两个查询的结果,通常采用以下形式:
<SELECT_STATEMENT_1> UNION <SELECT_STATEMENT_2>