慕娘9557946
2017-09-01 15:53
Mysql中Count(1)与Count(*)的区别是什么?
我找到了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,因此需要赋值给变量才能指定)。
1表示第一个字段,count(1)查询速度快一点
轻松愉快之玩转SpringData
34089 学习 · 119 问题
相似问题