问答详情
源自:4-4 Query注解使用

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

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

提问者:慕娘9557946 2017-09-01 15:53

个回答

  • 慕娘9557946
    2017-09-01 18:14:18

    我找到了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,因此需要赋值给变量才能指定)。


  • yanwang25
    2017-09-01 16:29:18

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