SQL使用Group by语句基于第二列值减去列值 [英] SQL Subtract Column Values Based on Second Column Value with Group By Statement
本文介绍了SQL使用Group by语句基于第二列值减去列值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有一条看起来像这样的SQL语句:
I have an SQL statement that looks so:
select FY_CD, PD_NO, INPUT, SUM(HOURS)
from LABOR_TABLE
group by PD_NO, INPUT;
返回此:
FY_CD|PD_NO| INPUT | HOURS
2008 1 Actuals 61000
2008 1 Baseline 59000
2008 2 Actuals 54000
2008 2 Baseline 59000
2008 3 Actuals 60000
2008 3 Baseline 70000
我正在尝试找出如何从每个期间的基准值中减去实际值,并返回以下内容:
I'm trying to figure out how to subtract the Actual values from the Baseline values for each period, returning the following:
FY_CD|PD_NO| INPUT | HOURS
2008 1 Variance 2000
2008 2 Variance -5000
2008 3 Variance -10000
感谢您的帮助.
推荐答案
实际上,您可以直接使用 CASE
检查 Input
的值来直接计算它,
You can actually calculate it directly by using CASE
to check the value of Input
,
SELECT FY_CD,
PD_NO,
'Variance' INPUT,
SUM(CASE WHEN Input = 'Actuals' THEN HOURS ELSE -1 * HOURS END) HOURS
FROM LABOR_TABLE
GROUP BY PD_NO
- SQLFiddle演示
这篇关于SQL使用Group by语句基于第二列值减去列值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文