(给视学算法加星标,提升数据技能)

转自:BigoSprite

https://blog.csdn.net/iFuMI/article/details/77920767

执行效果: 

1、count(1) and count(*)

当表的数据量大些时,对表作分析之后,使用count(1)还要比使用count(*)用时多了!

从执行计划来看,count(1)和count(*)的效果是一样的。但是在表做过分析之后,count(1)会比count(*)的用时少些(1w以内数据量),不过差不了多少。

如果count(1)是聚索引,id,那肯定是count(1)快。但是差的很小的。

因为count(*),自动会优化指定到那一个字段。所以没必要去count(1),用count(*),sql会帮你完成优化的 因此:count(1)和count(*)基本没有差别!

2、count(1) and count(字段)

两者的主要区别是

  1. count(1) 会统计表中的所有的记录数,包含字段为null 的记录。

  2. count(字段) 会统计该字段在表中出现的次数,忽略字段为null 的情况。即不统计字段为null 的记录。

转自:http://www.cnblogs.com/Dhouse/p/6734837.html

count(*) 和 count(1)和count(列名)区别

执行效果上: 

  • count(*)包括了所有的列,相当于行数,在统计结果的时候,不会忽略列值为NULL 

  • count(1)包括了忽略所有列,用1代表代码行,在统计结果的时候,不会忽略列值为NULL

  • count(列名)只包括列名那一列,在统计结果的时候,会忽略列值为空(这里的空不是只空字符串或者0,而是表示null)的计数,即某个字段值为NULL时,不统计

执行效率上:  

  • 列名为主键,count(列名)会比count(1)快

  • 列名不为主键,count(1)会比count(列名)快

  • 如果表多个列并且没有主键,则 count(1) 的执行效率优于 count(*)

  • 如果有主键,则 select count(主键)的执行效率是最优的

  • 如果表只有一个字段,则 select count(*)最优。

转自:http://eeeewwwqq.iteye.com/blog/1972576

实例分析

mysql> create table counttest(name char(1), age char(2));
Query OK, 0 rows affected (0.03 sec)mysql> insert into counttest values-> ('a', '14'),('a', '15'), ('a', '15'),-> ('b', NULL), ('b', '16'),-> ('c', '17'),-> ('d', null),->('e', '');
Query OK, 8 rows affected (0.01 sec)
Records: 8  Duplicates: 0  Warnings: 0mysql> select * from counttest;
+------+------+
| name | age  |
+------+------+
| a    | 14   |
| a    | 15   |
| a    | 15   |
| b    | NULL |
| b    | 16   |
| c    | 17   |
| d    | NULL |
| e    |      |
+------+------+
8 rows in set (0.00 sec)
mysql> select name, count(name), count(1), count(*), count(age), count(distinct(age))-> from counttest-> group by name;
+------+-------------+----------+----------+------------+----------------------+
| name | count(name) | count(1) | count(*) | count(age) | count(distinct(age)) |
+------+-------------+----------+----------+------------+----------------------+
| a    |           3 |        3 |        3 |          3 |                    2 |
| b    |           2 |        2 |        2 |          1 |                    1 |
| c    |           1 |        1 |        1 |          1 |                    1 |
| d    |           1 |        1 |        1 |          0 |                    0 |
| e    |           1 |        1 |        1 |          1 |                    1 |
+------+-------------+----------+----------+------------+----------------------+
5 rows in set (0.00 sec)

额外参考资料:

http://blog.csdn.net/lihuarongaini/article/details/68485838

推荐阅读

(点击标题可跳转阅读)

看完本文有收获?请转发分享给更多人

关注「视学算法」加星标,提升数据技能

好文章,我在看❤️

count(1)、count(*) 与 count (列名) 的执行区别相关推荐

  1. select count(*)加其他字段_count(1)、count(*) 与 count(列名) 的执行区别

    (给ImportNew加星标,提高Java技能) 作者:BigoSprite blog.csdn.net/iFuMI/article/details/77920767 执行效果: 1.  count( ...

  2. MySQL中count(1)、count(*) 与 count(列名) 的执行区别

    执行效果: 1.count(1) and count(*) 当表的数据量大些时,对表作分析之后,使用count(1)还要比使用count()用时多了! 从执行计划来看,count(1)和count() ...

  3. 面试官 | count(1)、count(*) 、count(列名) 有什么区别?

    作者 | BigoSprite 来源 | 39sd.cn/0926A 先看执行效果: 1.  count(1) and count(*) 当表的数据量大些时,对表作分析之后,使用count(1)还要比 ...

  4. 【优化】COUNT(1)、COUNT(*)、COUNT(常量)、COUNT(主键)、COUNT(ROWID)、COUNT(非空列)、COUNT(允许为空列)、COUNT(DISTINCT 列名)

    [优化]COUNT(1).COUNT(*).COUNT(常量).COUNT(主键).COUNT(ROWID).COUNT(非空列).COUNT(允许为空列).COUNT(DISTINCT 列名) 1. ...

  5. HiveSql面试题11详解(count(1)、count(*)和count(列名)的区别)

    从执行结果来看 - count(*)包括了所有的列,相当于行数,在统计结果的时候,不会忽略列值为NULL - count(1)包括了忽略所有列,用1代表代码行,在统计结果的时候,不会忽略列值为NULL ...

  6. count(*)和count(1)和count(列名)的区别

    count是一种最简单的聚合函数,一般也是我们第一个开始学习的聚合函数,那么他们之间究竟由什么区别呢? 有的人说count(1)和count(*)他们之间有区别,而有的人说他们之间没有区别那么他们之间 ...

  7. count(列名)与count(*)、count(1)的区别

    count()函数的作用是用来计算指定列或整个表中的函数,count()函数有以下三种写法:count(列名) .count(1).count(*) . 其中,count(列名)只统计当前列中非空值的 ...

  8. count(*)、count(1)和count(列名)的区别

    count(*).count(1)和count(列名)的区别 1.执行效果上:   l  count(*)包括了所有的列,相当于行数,在统计结果的时候,不会忽略列值为NULL l  count(1)包 ...

  9. mysql中对一个表的id建立了唯一索引,那么查询的select count(*) ,select count(1) ,select count(id),select count(列名)

    1.mysql中对一个表的id建立了唯一索引,那么查询的select count(*) ,select count(1) ,select count(id),select count(列名) 的查询结 ...

最新文章

  1. android timer后函数继续执行_一切从android的handler说起(三)
  2. 【万里征程——Windows App开发】控件大集合1
  3. sql注入mysql判断_sql注入笔记二——数据库信息判断
  4. 使用freemarker模板生成word文档
  5. cubes第六篇-sql支持
  6. Linux crontab 定时任务详解
  7. 编写一个程序,给出汉字“你”“我”“他”在Unicode表中的位置
  8. 【读书笔记】-《软件测试的艺术》
  9. vue路由 Maximum call stack size exceeded
  10. c语言 格式字符,c语言的格式符
  11. wifi动不动就断开_笔记本Wifi上网经常间歇性断网的修复
  12. 华为c8815手机在开发Android调试时logcat不显示输出信息的解决办法
  13. 对链特异性建库的理解
  14. 2021年茶艺师(中级)考试报名及茶艺师(中级)模拟考试题
  15. mysql存emoji_如何在MySQL中存储emoji?
  16. 领扣LintCode算法问题答案-83. 落单的数 II
  17. PDF Expert for mac(专业的PDF编辑器) 中文版
  18. 项目管理团队协作工具
  19. 一步一步掌握线程机制(六)---Atomic变量和Thread局部变量
  20. w3school css6,w3School jquery学习 选择器

热门文章

  1. Python 爬虫利器 Selenium 从入门到进阶
  2. 基于 Python 的 8 种常用抽样方法
  3. 10 个 Python 工程师,9 个不合格!
  4. 全球Python调查报告:Python 2正在消亡,PyCharm比VS Code更受欢迎
  5. 如何正确选择聚类算法? | CSDN博文精选
  6. 阿里披露AI完整布局,飞天AI平台首次亮相
  7. 知乎算法团队负责人孙付伟:Graph Embedding在知乎的应用实践
  8. OpenJDK官方正式宣布AWT、2D、Swing等项目解散
  9. 浅析操作系统和Netty中的零拷贝机制
  10. 为什么阿里巴巴禁止使用Apache Beanutils进行属性的copy?