登录  /  注册

MySQL关于Count函数的用法区别总结

藏色散人
发布: 2022-11-29 16:47:11
转载
1702人浏览过

前言

大家好,mysql关于count你知道多少

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

接下来我们来看一看他们之间有什么区别,以及他们是否存在一些坑。【推荐学习:MySQL视频教程

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

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

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

分析性能差别原则

  • server 层要什么就给什么;

  • InnoDB 只给必要的值;

  • 现在的优化器只优化了 count(*) 的语义为“取行数”,其他“显而易见”的优化并没有做

例子:

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

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

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

效率排序

count(字段)<count><p><a id="count_32"></a><strong>为什么count(*)最快?</strong></p>
<p>优化器做了工作,找到最小的数来遍历。</p>
<p>InnoDB 是索引组织表,主键索引树的叶子节点是数据,而普通索引树的叶子节点是主键值。所以,普通索引树比主键索引树小很多。对于 count(*) 这样的操作,遍历哪个索引树得到的结果逻辑上都是一样的。因此,MySQL 优化器会找到最小的那棵树来遍历。在保证逻辑正确的前提下,尽量减少扫描的数据量,是数据库系统设计的通用法则之一。</p>
<p><a id="NULL_38"></a><strong>关于NULL的几个坑</strong></p>
<pre class="brush:php;toolbar:false">// 数据中存在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(*)小结

  • MyISAM 表虽然 count(*) 很快,但是不支持事务;

  • show table status 命令虽然返回很快,但是不准确;

  • InnoDB 表直接 count(*) 会遍历全表,虽然结果准确,但会导致性能问题。

以上就是MySQL关于Count函数的用法区别总结的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
相关标签:
来源:csdn网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号