微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

sql中count(*)、count(col)、count(1)区别

count(*)和count(列)根本就是不等价的,count(*)是针对于全表的,而count(列)是针对于某一列的,如果此列值为空的话,count(列)是不会统计这一行的。

也就是说count(列)会用到索引,并且会过滤掉该列为null的那行。

而count(*)是全表扫描,并且只要某一条数据有一列不为null,那就会统计到这条数据。

 

count(1)可以理解为表里有一列数据都为1的列。

count(*),执行时会把星号翻译成字段的具体名字,效果也是一样的,不过多了一个翻译的动作,比固定值的方式效率稍微低一些。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐