选择带有多个子查询的查询以进行计数(Netezza SQL)

时间:2019-03-20 14:23:28

标签: sql netezza

我正在尝试创建一个报告,该报告在3个时间段内进行计数:上个月,去年的那个月和年初至今。

我以前在切换where子句时使用了以下3个单独的查询,但我希望能够将所有3个查询合并为一个查询。

我尝试了用case语句,但是似乎无法使它起作用。仅供参考app_dateYYYY-MM-DD

Select count(application_id)
from application_data a
where to_char(app_date, 'YYYYMM' = to_char(current_date, 'YYYYMM')-1
--where to_char(app_date, 'YYYYMM' = to_char(current_date, 'YYYYMM')-101
--where to_char(app_date, 'YYYY') = to_char(current_date, 'YYYY') and to_char(app_date, 'YYYYMM') <> to_char(current_date, 'YYYYMM')

样本数据:

App_ID          App_date  
123519          2018-02-17  
123521          2018-02-18  
123522          2018-02-19  
123523          2018-02-23  
123518          2019-01-15  
123546          2019-02-21  
123547          2019-02-22  
123548          2019-02-15  
123542          2019-02-02  

所需结果:

LastMonth      YTD       YoY  
4               5         4

1 个答案:

答案 0 :(得分:1)

我认为您需要条件聚合:

Select sum(case when to_char(app_date, 'YYYYMM' = to_char(current_date, 'YYYYMM')-1 then 1 else 0 end),
       sum(case to_char(app_date, 'YYYYMM' = to_char(current_date, 'YYYYMM')-101 when then 1 else 0 end),
       sum(case when to_char(app_date, 'YYYY') = to_char(current_date, 'YYYY') and to_char(app_date, 'YYYYMM') <> to_char(current_date, 'YYYYMM') then 1 else 0 end)
from application_data a