为了账号安全,请及时绑定邮箱和手机立即绑定

count(*)和count(1)区别?

count(*)和count(1)区别?

MMTTMM 2019-03-20 22:19:37
count(*)和count(1)区别?
查看完整描述

2 回答

?
阿波罗的战车

TA贡献1862条经验 获得超6个赞

以下sql可以看到你的sql会被mysql转译成怎样


EXPLAIN EXTENDED

SELECT count(*) FROM `table`;

SHOW WARNINGS;

我的版本是mysql 5.6.26,以下是转译后的结果:


/* select#1 */ select count(0) AS `count(*)` from `test`.`table`

所以,在我看来,较新版本的mysql已经没这方面的区别了,不过习惯上我还是使用count(1)。


查看完整回答
反对 回复 2019-04-22
?
尚方宝剑之说

TA贡献1788条经验 获得超4个赞

在数据记录都不为空的时候查询出来结果上没有差别的. 但当COUNT(1)查询的那列有空的时候空的是要被去掉的不记入统计中.这样查询出来的结果是不一样的.


查看完整回答
反对 回复 2019-04-22
  • 2 回答
  • 0 关注
  • 672 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信