加入收藏 | 设为首页 | 会员中心 | 我要投稿 51站长网 (https://www.51zhanzhang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
站内搜索:
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql – 选择distinct count(id)vs select count(distinct id)

发布时间:2021-03-13 18:26:13 所属栏目:MySql教程 来源:网络整理
导读:我正试图从表中获取不同的值.当我从表中运行select distinct count(id)时,我得到了超过一百万的计数.但是,如果我从表中运行select count(distinct id),我只有大约300k计数.这两个查询的区别是什么? 谢谢 最佳答案当您选择非重复计数(id)时,您基本上在做: s

我正试图从表中获取不同的值.当我从表中运行select distinct count(id)时,我得到了超过一百万的计数.但是,如果我从表中运行select count(distinct id),我只有大约300k计数.这两个查询的区别是什么?

谢谢

最佳答案 当您选择非重复计数(id)时,您基本上在做:

select distinct cnt
from (select count(id) as cnt from t) t;

因为内部查询只返回一行,所以distinct不执行任何操作.查询计算表中的行数(更准确地说,id不为null的行数).

另一方面,当你这样做时:

select count(distinct id)
from t;

然后查询计算id在表中所采用的不同值的数量.这似乎是你想要的.

(编辑:ASP站长)

【免责声明】本站内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。

    相关内容
    未处理完善
      无相关信息
    未处理完善