oracle group by分类查询汇总 没数据的时候让此项显示为0

1.表数据

表名:table

iddate
12019-05
22019-06
32019-04
42019-06

2.需求

现在要求按照指定五个月份统计每个月的数量,这五个月份为:
(‘2019-02’,‘2019-03’,‘2019-04’,‘2019-05’,‘2019-06’)
查询出来的数据应该是这样的

datenum
2019-020
2019-030
2019-041
2019-051
2019-062

3.实现

3.1按照常规写法

select date,count(*) as num from  table
where DATE in ('2019-02','2019-03','2019-04','2019-05','2019-06')
group by dates
order by dates desc

然后发现出来的数据是这样的

datenum
2019-041
2019-051
2019-062

3.2解决
我想到的解决思路是将这几个月份查成一张临时表做一个left join 这样月份就固定会显示在那,再使用nvl判断num为NULL的时候添加为0

select A.date,nvl(num,0) 
from (
--固定写法,按照逗号分隔成一列
	SELECT DISTINCT REGEXP_SUBSTR ('2019-02,2019-03,2019-04,2019-05,2019-06','[^,]+',1,LEVEL) as date
	FROM DUAL
	CONNECT BY REGEXP_SUBSTR ('2019-02,2019-03,2019-04,2019-05,2019-06','[^,]+',1,LEVEL) IS NOT NULL
) A
LEFT JOIN 
(
--归类查询
	select count(*) as num,date from GREEN_ATTENDANCE
	where DATE in ('2019-02','2019-03','2019-04','2019-05','2019-06')
	group by date
) B
on A.date=B.date

这样写会有点繁琐了,如有更好的办法请指教

posted @ 2019-07-24 10:20  Teler  阅读(1721)  评论(0)    收藏  举报