为了账号安全,请及时绑定邮箱和手机立即绑定

Count(1)与Count(*)的区别是什么?

Mysql中Count(1)与Count(*)的区别是什么?

正在回答

2 回答

我找到了Sql Server 的:  没有找到Mysql的

在SQL Server中Count(*)或者Count(1)或者Count([列])或许是最常用的聚合函数。很多人其实对这三者之间是区分不清的。本文会阐述这三者的作用,关系以及背后的原理。

    往常我经常会看到一些所谓的优化建议不使用Count(* )而是使用Count(1),从而可以提升性能,给出的理由是Count( *)会带来全表扫描。而实际上如何写Count并没有区别。

 Count(1)和Count(*)实际上的意思是,评估Count()中的表达式是否为NULL,如果为NULL则不计数,而非NULL则会计数。比如我们看代码1所示,在Count中指定NULL(优化器不允许显式指定NULL,因此需要赋值给变量才能指定)。


0 回复 有任何疑惑可以回复我~

1表示第一个字段,count(1)查询速度快一点

0 回复 有任何疑惑可以回复我~
#1

慕娘9557946 提问者

count(数字)应该不是指的某一列,因为我把所有age置Null count(2) 还是统计的是所有条目的数量,如果写COUNT(age)就是0,所以我推断出数字不是指定某个列。
2017-09-01 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

Count(1)与Count(*)的区别是什么?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信