免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3317 | 回复: 5
打印 上一主题 下一主题

分公司汇总,结果为0也要求显示的SQL怎样写? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-05-30 08:28 |只看该作者 |倒序浏览
t_a是存放公司信息的表,其中comcode是公司代码,唯一索引;
t_b是存放销售单的表,其中有字段comcode,定单ID字段ddid,还有日期字段xdate;
现在要提取20070520当天各公司销售单的数量,即使数量为0也要求显示出来。应该怎么写?

select a.comcode,count(b.ddid)
from t_a a left join t_b on a.comcode=b.comcode
where b.xdate="20070520"
group by 1

可以汇总有销售单的公司,为0的就显示不出来了。
求助!

论坛徽章:
0
2 [报告]
发表于 2007-05-30 08:37 |只看该作者
补充,如果用以下SQL
select a.comcode,count(b.ddid)
from t_a a left join t_b on a.comcode=b.comcode
where b.xdate="20070520" or b.xdate is null
group by 1
可以实现,但是速度太慢,而且总觉得不大理想。

论坛徽章:
0
3 [报告]
发表于 2007-05-30 09:55 |只看该作者
select a.comcode,case when b.ddid is null then 0 else   count(b.ddid) end
from t_a a left join t_b on a.comcode=b.comcode
where b.xdate="20070520"
group by 1

论坛徽章:
0
4 [报告]
发表于 2007-05-30 10:03 |只看该作者
select a.comcode,count(b.ddid)
from t_a a left join t_b on a.comcode=b.comcode
where b.xdate="20070520"
group by 1
having count(b.ddid>=0)
不知道这样做可不可以实现

论坛徽章:
0
5 [报告]
发表于 2007-05-30 17:10 |只看该作者
lavanyy的不行,之前就试过,只能显示不为0的。
yxdth2006的应该可行

论坛徽章:
0
6 [报告]
发表于 2007-06-27 16:08 |只看该作者
楼主试试:
select a.comcode,nvl(count(b.ddid),0) count
from t_a a ,outer  t_b  b
where a.comcode=b.comcode and b.xdate="20070520"
group by 1
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP