0

如果该行存在但我的“where”条件中没有金额,我需要输入金额“0”。

原来的命令是:

select t.aaa, count (t.bbb), sum (t.ccc)
from nrb t
where t.vvv IN  ('3','4','5','6','D','E','F')
  and t.ddd like '50%'
  and t.eee >= TO_DATE('2012/03/21','YYYY/MM/DD')
  and t.eee <= TO_DATE('2012/07/21','YYYY/MM/DD')
group by t.aaa
order by t.aaa

结果是:excel文件中的“结果”选项卡。

我需要这个结果:excel文件中的“结果2”选项卡。

文件:我确实发送了完整的结果。 http://www.mediafire.com/?69cc4ay6cyt9cr9

我怎么能有这个?

pl/sql 7.0.2 无限用户许可

oci:9.2

oracle 数据库:11.1.0.6.0 企业版

操作系统:赢XP

4

1 回答 1

1

你可能想要:

select t1.aaa, coalesce(t2.bbb_count, 0) bbb_count,
    coalesce(t2.ccc_sum, 0) ccc_sum
from (
  select distinct aaa
  from nrb
) t1
left join (
  select t.aaa, count (t.bbb) bbb_count, sum (t.ccc) ccc_sum
  from nrb t
  where t.vvv IN  ('3','4','5','6','D','E','F')
    and t.ddd like '50%'
    and t.eee >= TO_DATE('2012/03/21','YYYY/MM/DD')
    and t.eee <= TO_DATE('2012/07/21','YYYY/MM/DD')
  group by t.aaa
) t2 on t1.aaa = t2.aaa
order by t1.aaa;
于 2012-07-28T11:55:22.650 回答