MySQL关于Count你知道多少

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介: 统计数据的需求在我们日常开发中是非常容易遇到了,MySQL也支持多种的计算的函数,

前言

大家好,我是小郭,MySQL关于Count你知道多少

统计数据的需求在我们日常开发中是非常容易遇到了,MySQL也支持多种的计算的函数,

接下来我们来看一看他们之间有什么区别,以及他们是否存在一些坑。

count(*)、count(1)、count(id)的区别

count的含义:count() 是一个聚合函数,对于返回的结果集,一行行地判断,如果 count 函数的参数不是 NULL,累计值就加 1,否则不加。最后返回累计值。

count(字段)比较特殊,则表示返回满足条件的数据行里面,参数“字段”不为 NULL 的总个数

分析性能差别原则

  1. server 层要什么就给什么;
  2. InnoDB 只给必要的值;
  3. 现在的优化器只优化了 count(*) 的语义为“取行数”,其他“显而易见”的优化并没有做

例子:

count(主键 id) 来说,InnoDB 引擎会遍历整张表,把每一行的 id 值都取出来,返回给 server 层。server 层拿到 id 后,判断是不可能为空的,就按行累加。

count(1) 来说,InnoDB 引擎遍历整张表,但不取值。server 层对于返回的每一行,放一个数字“1”进去,判断是不可能为空的,按行累加。

count(字段),server要字段,就返回字段,如果字段为空,就不做统计,字段的值过大,都会造成效率低下。

效率排序

count(字段)<count(主键 id)<count(1)≈count(*)

为什么count(*)最快?

优化器做了工作,找到最小的数来遍历。

InnoDB 是索引组织表,主键索引树的叶子节点是数据,而普通索引树的叶子节点是主键值。所以,普通索引树比主键索引树小很多。对于 count(*) 这样的操作,遍历哪个索引树得到的结果逻辑上都是一样的。因此,MySQL 优化器会找到最小的那棵树来遍历。在保证逻辑正确的前提下,尽量减少扫描的数据量,是数据库系统设计的通用法则之一。

关于NULL的几个坑

// 数据中存在null值数据
select count(*) from audit_log a;
结果:1
select count(id) from audit_log a;
结果:0

我们看到count的结果不一致,记录数应该是1,count(id)却等于0

这是因为count(字段)是不统计,字段值为null的值

所以在字段为非空字段的情况下,需要使用count(*)来解决这个问题。

count(*)小结

  1. MyISAM 表虽然 count(*) 很快,但是不支持事务;
  2. show table status 命令虽然返回很快,但是不准确;
  3. InnoDB 表直接 count(*) 会遍历全表,虽然结果准确,但会导致性能问题。
相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
10月前
|
关系型数据库 MySQL
mysql统计数据表中同一字段不同状态的COUNT()语句
mysql统计数据表中同一字段不同状态的COUNT()语句
67 0
|
6月前
|
SQL 关系型数据库 MySQL
解决MySQL count统计数目错误的问题
解决MySQL count统计数目错误的问题
51 0
|
7月前
|
SQL 算法 关系型数据库
【MySQL系列】统计函数(count,sum,avg)详解
文章目录 🌈一、COUNT函数 创建一个表T1 1.COUNT函数的定义: 2.COUNT函数的使用方式: 1️⃣count(*) (1)count(*)定义: (2)具体使用: (3)
|
7月前
|
NoSQL 关系型数据库 MySQL
MySQL学习笔记-不同count统计的比较
MySQL学习笔记-不同count统计的比较
42 0
|
9月前
|
SQL 存储 关系型数据库
为什么mysql的count()方法这么慢?
为什么mysql的count()方法这么慢?
71 0
|
9月前
|
关系型数据库 MySQL 数据挖掘
数据统计与计数:解析MySQL中的COUNT()函数
在数据库管理中,统计某一列数据的行数是常见的数据分析任务,COUNT()函数正是用于帮助我们实现这一目标的工具。
157 0
|
10月前
|
关系型数据库 MySQL 索引
【MySQL】count(1)、count(*)、count(字段)、count(主键)的区别
【MySQL】count(1)、count(*)、count(字段)、count(主键)的区别
166 0
|
11月前
|
SQL 存储 关系型数据库
MySQL中count(*)和information_schema.tables中的table_rows值不相同
MySQL中count(*)和information_schema.tables中的table_rows值不相同
274 0
|
11月前
|
存储 关系型数据库 MySQL
MySQL中count是怎样执行的?———count(1),count(id),count(非索引列),count(二级索引列)的分析
MySQL中count是怎样执行的?———count(1),count(id),count(非索引列),count(二级索引列)的分析
119 0
MySQL中count是怎样执行的?———count(1),count(id),count(非索引列),count(二级索引列)的分析
|
12月前
|
存储 SQL 安全
Mysql报错注入原理分析(count()、rand()、group by)
Mysql报错注入原理分析(count()、rand()、group by)
173 0