如何在查询结果中为不存在的行添加0数据?

时间:2012-10-18 07:11:39

标签: sql oracle plsql

我的表有列:“月”和“年”,以及其他数据。

表中的所有行都有不同的值“月”和“年”。<​​/ p>

但是对于某些月份和年份行不存在。

我想创建SQL查询(...其中年份(2010,2011,2012)...),结果这个SQL查询具有选定年份的所有月份,如果某个月不存在其他月份将其添加到其他数据列中的结果为0。

实施例: 输入:表

data / month / year
+-----+---+------+
| 3.0 | 1 | 2011 |
| 4.3 | 3 | 2011 |
| 5.7 | 4 | 2011 |
| 2.2 | 5 | 2011 |
| 5.4 | 7 | 2011 |
+-----+---+------+

输出:SELECT ...年份IN(2011)

+-----+----+------+
| 3.0 |  1 | 2011 |
|   0 |  2 | 2011 |
| 4.3 |  3 | 2011 |
| 5.7 |  4 | 2011 |
| 2.2 |  5 | 2011 |
|   0 |  6 | 2011 |
| 5.4 |  7 | 2011 |
|   0 |  8 | 2011 |
|   0 |  9 | 2011 |
|   0 | 10 | 2011 |
|   0 | 11 | 2011 |
|   0 | 12 | 2011 |
+-----+----+------+

3 个答案:

答案 0 :(得分:3)

尝试Partition Outer Join

SELECT
  NVL(T.DATA, 0) DATA,
  F.MONTH,
  T.YEAR
FROM <your_table> T
PARTITION BY(T.YEAR)
RIGHT JOIN (SELECT LEVEL MONTH FROM DUAL CONNECT BY LEVEL <= 12) F ON T.MONTH = F.MONTH

在最后添加WHERE子句,或者创建一个包含该定义和查询的视图。

答案 1 :(得分:2)

select datecol, 
       nvl(val,0),
       to_char(d.date_col,'MM') month,
       to_char(d.date_col,'yyyy') year
from(
    select add_months('1-Jan-2011',level-1) as datecol
    from dual connect by level <= 12
     ) d
left join(
    select sum(val) as val, month, year
    from your_table
    group by month, year
    ) S
on (to_char(d.date_col,'MM') = s.month and to_char(d.date_col,'yyyy') = s.year)

答案 2 :(得分:0)

select nvl(t.data, 0), x.month, nvl(t.year, <your_year>) as year
  from <your_table> t,
       (select rownum as month from dual connect by level < 13) x
 where (t.year is null or t.year = <your_year>)
   and t.month(+) = x.month
 order by x.month