
select distinct count 的用法
selectdistinctcount(xm)fromgyjmwherehbh='6252'andhkbbh='609000343';selectdistincthzxm...
select distinct count(xm) from gyjm where hbh='6252' and hkbbh='609000343';
select distinct hzxm from gyjm where hbh='6252' and hkbbh='609000343';
上面两句都能得到正确的结果,但是两条合起来就报错:
select distinct hzxm,count(xm) from gyjm where hbh='6252' and hkbbh='609000343'; 报错:0ra-00937:不是单组分组函数?怎么办?
问题答案:
count是分组函数,不能和distinct合用,实际上分组函数已经起了distinct的作用.正确的写法是:
select hzxm,count(xm) from gyjm where hbh='6252' and hkbbh='609000343' group by hzxm; 展开
select distinct hzxm from gyjm where hbh='6252' and hkbbh='609000343';
上面两句都能得到正确的结果,但是两条合起来就报错:
select distinct hzxm,count(xm) from gyjm where hbh='6252' and hkbbh='609000343'; 报错:0ra-00937:不是单组分组函数?怎么办?
问题答案:
count是分组函数,不能和distinct合用,实际上分组函数已经起了distinct的作用.正确的写法是:
select hzxm,count(xm) from gyjm where hbh='6252' and hkbbh='609000343' group by hzxm; 展开
2个回答
推荐于2018-05-09
展开全部
楼主已经自己把问题解决了,
我来再补充一下
count 是能和distinct合用 的.
具体使用方式是
select
hzxm,
count( DISTINCT xm)
from
gyjm
where
hbh='6252' and hkbbh='609000343'
group by
hzxm;
上面的 count( DISTINCT xm)
意思就是, 如果在按照 hzxm 分组的时候, 遇到 重复的 xm , 那么只计算一次。
实际应用的例子, 就是 比如我要查询 本月的考勤
每个员工本月的 打卡次数。
可能某人 某天刷了 2下或者3下。
但是 count( DISTINCT 打卡日期 ) 将只计算1次。
我来再补充一下
count 是能和distinct合用 的.
具体使用方式是
select
hzxm,
count( DISTINCT xm)
from
gyjm
where
hbh='6252' and hkbbh='609000343'
group by
hzxm;
上面的 count( DISTINCT xm)
意思就是, 如果在按照 hzxm 分组的时候, 遇到 重复的 xm , 那么只计算一次。
实际应用的例子, 就是 比如我要查询 本月的考勤
每个员工本月的 打卡次数。
可能某人 某天刷了 2下或者3下。
但是 count( DISTINCT 打卡日期 ) 将只计算1次。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询