是否有可能创建一个查询,该查询将输出带有2个不同WHERE子句的2列
这是我理想的输出:
| YEAR | WW | COUNT | *COUNT2 |
其中count 1是第一个WHERE子句的结果。我已经创建了。我想要的是在值中的另一列中使用不同的WHERE子句。
这是我的查询:
SELECT extract(YEAR FROM EVT_TARGET) as Years, to_char(EVT_TARGET, 'ww') AS WorkWeek, COUNT(*)
FROM r5events
WHERE EVT_JOBTYPE = 'CORR' AND EVT_RSTATUS <> 'C' AND EVT_TARGET IS NOT NULL
GROUP BY extract(YEAR FROM EVT_TARGET), to_char(EVT_TARGET, 'ww');
通过此查询,我能够获得第1 3列,现在的问题是如何在第4列中提供的值EVT_RSTATUS = 'C'
。
有见识吗?
TIA
我认为您需要条件聚合:
SELECT
extract(YEAR FROM EVT_TARGET) as Years,
to_char(EVT_TARGET,'ww') AS WorkWeek,
SUM(CASE WHEN EVT_RSTATUS <> 'C' THEN 1 ELSE 0 END) AS cnt1,
SUM(CASE WHEN EVT_RSTATUS = 'C' THEN 1 ELSE 0 END) AS cnt2
FROM r5events
WHERE EVT_JOBTYPE ='CORR' AND EVT_TARGET IS NOT NULL
GROUP BY extract(YEAR FROM EVT_TARGET), to_char(EVT_TARGET,'ww');
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句