MySQL中count(0)、count(1)和count(*)的区别

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(*)。

参考链接:https://deepinout.com/mysql/mysql-questions/1053_mysql

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值