count(0)
使用count(0),实际上是告诉MySQL计算表中0的个数,这里的0是一个常量,跟数据无关。因为count()函数忽略NULL值,而0在MySQL中被定义为可以转换成任何数据类型的常量,因此使用count(0)和count(*)的结果是一样的。
SELECT COUNT(0) FROM `table_name`;
count(1)
使用count(1),实际上是告诉MySQL计算表中1的个数,这里的1也是一个常量,跟数据无关。跟count(0)一样,因为count()函数忽略NULL值,而1在MySQL中被定义为可以转换成任何数据类型的常量,因此使用count(1)和count(*)的结果也是一样的。
SELECT COUNT(1) FROM `table_name`;
count(*)
使用count(*),意味着计算表中所有行的行数,包括NULL值和重复值。使用count(*)比使用count(0)和count(1)更加直观,因为它没有与表中任何特定的列相关。
SELECT COUNT(*) FROM `table_name`;
总结
在使用count()函数计算表中数据行数时,count(0)和count(1)会忽略NULL值,但结果与count(*)一致。而使用count(*)时则会计算所有数据行数,包括NULL值和重复值。在通常情况下,我们更推荐使用count(*)。
2087

被折叠的 条评论
为什么被折叠?



