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

来源:4-4 Query注解使用

慕娘9557946

2017-09-01 15:53

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

写回答 关注

2回答

  • 慕娘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)查询速度快一点

    慕娘9557...

    count(数字)应该不是指的某一列,因为我把所有age置Null count(2) 还是统计的是所有条目的数量,如果写COUNT(age)就是0,所以我推断出数字不是指定某个列。

    2017-09-01 18:13:43

    共 1 条回复 >

轻松愉快之玩转SpringData

利用Spring Data提高开发效率,提升程序员的幸福指数

34087 学习 · 119 问题

查看课程

相似问题