文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

mysql中count( *)、count( 1)、count( 主键)、count( 字段)的区别说什么

2024-04-02 19:55

关注

小编给大家分享一下mysql中count( *)、count( 1)、count( 主键)、count( 字段)的区别说什么,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!

  select count( *)应该是一个比较常用的语句,用来统计记录行数。但是,慢慢地你会发现,这个语句越来越慢了,为什么呢?

  MySQL 中,不同的存储引擎,count( *)的实现方式是不同的。

  1、MyISAM 引擎,比较简单粗暴,直接将表的总行数存储在磁盘上,因此效率很高;

  2、InnoDB 引擎中,执行count(*)时会遍历全表,需要一行行的把数据查出来,因此性能较差;

  为啥 MyISAM 就可以这样做呢?因为它不支持事务啊,不用担心数据不一致的问题,因此可以快速返回count(*)。

  假设,表 t 中有 1000 条数据,有下面三个用户并行的会话:

  1、A 启动事务,查询表的总行数;

  2、C 直接插入一条数据,然后查询总行数;

  3、B 启动事务,插入一条数据,然后查询总行数;

  4、C 查询总行数;

  注意,上面启动的事务都没有提交。

  A、B、C 查询的结果都不相同。

  B 读到的是 1002,是因为可重复读隔离级别的存在。

  而 C 未开启事务,因此无法看到别的事务的更新。

  InnoDB 中,主键索引存储的是数据,辅助索引存储的只是主键值。辅助索引比主键索引小得多,轻量得多。

  这种情况下,InnoDB 在执行count( *)时,就会判断使用哪个索引,会选择最小的树来进行遍历。在保证逻辑正确的前提下,尽量减少扫描的数据量,是数据库系统设计的通用法则之一。

  综上,InnoDB 引擎中,在每一个会话中,都需要逐行读取数据,对 count( *) 优化,然后计数返回总行数。

  count( *)、count( 1)、count( 主键)、count( 字段)的区别

  (1)对于count(主键id),InnoDB 会遍历全表,取每行的主键 id,返回给 server 层,server 层拿到数据后,进行判断累加。

  (2)对于count(1),InnoDB 仍遍历全表,但是不取值,server 层对返回的每一行数据新增一个 1,然后进行判断累加;

  (3)对于count( 字段):

  1、如果这个“字段”是定义为 not null 的话,一行行地从记录里面读出这个字段,判断不能为 null,按行累加

  2、如果这个“字段”定义允许为 null,那么执行的时候,判断到有可能是 null,还要把值取出来再判断一下,不是 null 才累加。

  性能区别:

  1.列名为主键, count( 1) = count( *)= count( 列名)

  2.列名不为主键, count( 1) = count( *) > count( 列名)

  3.列名不为主键, 列名创建索引count( 1) = count(*)= count( 列名)

  使用选择:

  1.COUNT( *)和COUNT( 1)本质上一样,具体响应时间跟存储引擎和WHERE条件有关。个人习惯使用COUNT( *)。

  2.索引对COUNT()函数很重要,如果要用到索引,MySQL会自动优化使用合适的索引。

  3.COUNT( 列名)需要注意统计的是非NULL的列。

看完了这篇文章,相信你对“mysql中count( *)、count( 1)、count( 主键)、count( 字段)的区别说什么”有了一定的了解,如果想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯