本文主要是介绍oracle group by分类查询汇总 没数据的时候让此项显示为0,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
1.表数据
表名:table
id | date |
---|---|
1 | 2019-05 |
2 | 2019-06 |
3 | 2019-04 |
4 | 2019-06 |
2.需求
现在要求按照指定五个月份统计每个月的数量,这五个月份为:
(‘2019-02’,‘2019-03’,‘2019-04’,‘2019-05’,‘2019-06’)
查询出来的数据应该是这样的
date | num |
---|---|
2019-02 | 0 |
2019-03 | 0 |
2019-04 | 1 |
2019-05 | 1 |
2019-06 | 2 |
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
然后发现出来的数据是这样的
date | num |
---|---|
2019-04 | 1 |
2019-05 | 1 |
2019-06 | 2 |
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 dateFROM DUALCONNECT 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_ATTENDANCEwhere DATE in ('2019-02','2019-03','2019-04','2019-05','2019-06')group by date
) B
on A.date=B.date
这样写会有点繁琐了,如有更好的办法请指教
这篇关于oracle group by分类查询汇总 没数据的时候让此项显示为0的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!