mysql——count(*)、count(1)和count(字段)谁更快?有什么区别?

目录

一、count(*)、count(1)和count(属性)谁更快?有什么区别?

1.1、示例

  • 例如表结构及数据如下图:

  • 分别执行如下3条sql语句

    java 复制代码
    SELECT count(*) FROM t_user;
    SELECT count(1) FROM t_user;
    SELECT count(names) FROM t_user;

1.2、count(*)、count(1)和count(属性)区别

1.2.1、语义区别‌
  • count(*) 返回3条数据

    说明统计 满足条件的结果集的总行数,包括所有行(无论是否包含NULL值

  • count(1) 返回3条数据

    说明与count(*)功能相同,统计所有行数

  • count(names) 返回2条数据

    说明统计该字段非NULL的行数(若字段允许NULL,则仅统计非NULL值)

1.2.2、count(*)和count(1)在功能和性能上区别
  • mysql官网上表示count(*)和count(1)在功能和性能上没有任何区别,下图为官网截图:

  • 通过explian执行计划查看,如下图:

    java 复制代码
    explain SELECT count(*) FROM `t_user`;
    show WARNINGS;
  • 可以看到mysql底层对这个查询进行了sql优化,把 count(*) 优化成了count(0),其中count(0)和count(1)是没有任何区别的,只是为了标记当前这条数据存在的一个常量,所以优化完之后的这个**count(*)**跟count(1)肯定是没有任何性能上的区别。

  • 如果非要进行比较的话,肯定还是 **count(*)**比count(1)略胜一筹,因为它不需要mysql在底层进行任何的sql优化。

相关推荐
川石课堂软件测试19 小时前
Python | 高阶函数基本应用及Decorator装饰器
android·开发语言·数据库·python·功能测试·mysql·单元测试
奇点 ♡1 天前
MySQL基础题
数据库·sql·mysql
cherry52301 天前
Java大厂面试真题:Spring Boot + 微服务 + 缓存架构三轮技术拷问实录
jvm·spring boot·mysql·微服务·java面试·分布式架构·redis缓存
唐古乌梁海1 天前
【mysql】MySQL 数据库迁移
数据库·mysql·adb
JanelSirry1 天前
真实场景:防止缓存穿透 —— 使用 Redisson 布隆过滤器
数据库·mysql·缓存·redisson·布隆过滤器
mmm.c1 天前
mysql启动提示1067:进程意外终止
数据库·mysql
一叶飘零_sweeeet1 天前
MySQL 锁详解
mysql·innodb
沐伊~1 天前
mysql 安装
数据库·mysql
成为你的宁宁1 天前
Ubuntu安装mysql5.7及常见错误问题
linux·mysql·ubuntu
努力学习的小廉1 天前
初识MYSQL —— 复合查询
android·数据库·mysql