首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    性能大PK count(*)、count(1)和count(列)

    印象中网上有些“XX 面试官”系列的网文也有过类似问题的讨论,那 MySQL 统计数据总数 count(*) 、count(1)和count(列名) 哪个性能更优呢?今天我们就来聊一聊这个问题。...count(*) 性能与存储引擎相关 我们都知道,MySQL 常见的存储引擎有两种:MyISAM 和 InnoDB。...count(1) 和 count() 对比 当表的数据量大些时,对表作分析之后,使用 count(1)还要比使用 count(*)用时多了!...从执行计划来看, count(1) 和 count(*)的效果是一样的。但是在表做过分析之后, count(1) 会比 count(*)的用时少些(1w以内数据量),不过差不了多少。...因为 count(*)自动会优化指定到那一个字段,所以没必要去 count(1),用 count(*) sql会帮你完成优化的,因此:count(1) 和 count(*)基本没有差别!

    2.1K10

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

    )比count(*)快 若表只有一个字段,count(*)最快 count(1)跟count(主键)一样,只扫描主键 count(*)跟count(非主键)一样,扫描整个表 明显前者更快。...执行效果 count(1) V.S count(*) 表数据量大,对表分析后,用count(1)还要比用count()用时多! 执行计划看,count(1)和count(*)效果一样。...因为count(*)会自动优化指定到那一个字段。所以没必要去count(1),用count(*),sql会帮你完成优化。 因此:count(1)和count(*)基本无差。...count(*) count(1) count(列名) count(*)包括所有列,相当于行数。统计结果时,不忽略列值为NULL count(1)包括了忽略所有列,1代表代码行。...(name), count(1), count(*), count(age), count(distinct(age)) -> from counttest -> group by name

    4.7K20

    MySQL中count(字段) ,count(主键 id) ,count(1)和count(*)的区别

    注:下面的讨论和结论是基于 InnoDB 引擎的。 首先要弄清楚 count() 的语义。...所以,count(*)、count(1)和count(主键 id) 都表示返回满足条件的结果集的总行数;而 count(字段),则表示返回满足条件的数据行里面,参数“字段”不为 NULL 的总个数。...count(可空字段) 扫描全表,读到server层,判断字段可空,拿出该字段所有值,判断每一个值是否为空,不为空则累加 count(非空字段)与count(主键 id) 扫描全表,读到server层,...注意:count(1)执行速度比count(主键 id)快的原因:从引擎返回 id 会涉及到解析数据行,以及拷贝字段值的操作。 count(*) MySQL 执行count(*)在优化器做了专门优化。...性能对比结论 count(可空字段) count(非空字段) = count(主键 id) count(1) ≈ count(*)

    3.5K30

    MySQL中count(字段) ,count(主键 id) ,count(1)和count(*)的区别

    注:下面的讨论和结论是基于 InnoDB 引擎的。 首先要弄清楚 count() 的语义。...所以,count(*)、count(1)和count(主键 id) 都表示返回满足条件的结果集的总行数;而 count(字段),则表示返回满足条件的数据行里面,参数“字段”不为 NULL 的总个数。...count(可空字段) 扫描全表,读到server层,判断字段可空,拿出该字段所有值,判断每一个值是否为空,不为空则累加 count(非空字段)与count(主键 id) 扫描全表,读到server层,...注意:count(1)执行速度比count(主键 id)快的原因:从引擎返回 id 会涉及到解析数据行,以及拷贝字段值的操作。 count(*) MySQL 执行count(*)在优化器做了专门优化。...性能对比结论 count(可空字段) count(非空字段) = count(主键 id) count(1) ≈ count(*) 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

    3.7K10

    MySQL中count(*)、count(主键id)、count(字段)和count(1)那种效率更高?

    但是,在实际使用过程中,我们可能会遇到不同的 COUNT 函数写法,比如 COUNT(*)、COUNT(主键id)、COUNT(字段) 和 COUNT(1),这些写法在效率上有何差别呢?...但需要注意的是,只有在表没有 WHERE 子句和 GROUP BY 子句时,才能使用这种优化方式。...COUNT(字段) 表示计算该字段不为 NULL 的记录数,而 COUNT(1) 表示计算所有行数,这里需要注意的是,COUNT(1) 和 COUNT(*) 的作用是相同的。...综上所述,我们可以得出以下结论:当查询的表中不存在 WHERE 子句和 GROUP BY 子句时,COUNT(*) 可能比 COUNT(主键id) 稍微快一点。...在单表查询时,COUNT(1) 和 COUNT(字段) 的性能通常相同,因为它们使用的优化方案也相同。在多表查询时,COUNT(1) 通常比 COUNT(字段) 更快。

    2.3K30

    MySQL中count(*)、count(主键id)、count(字段)和count(1)那种效率更高?

    在select count(?) from t这样的查询语句里面,count(*)、count(主键id)、count(字段)和count(1)等不同用法的性能,有哪些差别。...所以,count(*)、count(主键id)和count(1) 都表示返回满足条件的结果集的总行数;而count(字段),则表示返回满足条件的数据行里面,参数“字段”不为NULL的总个数。...所以结论是: 按照效率排序的话,count(字段)count(主键id)count(1)≈count(*),所以我建议你,尽量使用count(*)。...其实,把计数放在Redis里面,不能够保证计数和MySQL表里的数据精确一致的原因,是这两个不同的存储构成的系统,不支持分布式事务,无法拿到精确一致的视图。...InnoDB引擎支持事务,我们利用好事务的原子性和隔离性,就可以简化在业务开发时的逻辑。这也是InnoDB引擎备受青睐的原因之一。

    5.5K50

    大白话讲解Mysql执行计划

    subquery 和外部表无关联 subquery(标量子查询)执行计划没错误,不代表sql执行没错(不能超过1行数据,subquery return more than 1 row) dependent...subquery 必须依附于外面的值 scala subquery(和外部有关系的标量子查询) exists derived unin/union all group by distinct 聚合函数...5.7中optimizer_switch='derived_merge=on'可以把简单subquery打开成join derived_merge为on时被驱动表的连接条件要有索引,为off时被驱动表结果集要小...中使用hint QB_NAME,外层使用这个hint 1.3 table NULL 表示不使用任何表 使用dual extra中出现select tables optimized away,多见于count...optimized away 查询中只有min、max的时候出现,有时候count貌似也会出现 联合主键,其中任一一个字段用等值查询,查出另一个字段的min或max,且不能包含group by Using

    1.1K10

    理解PG如何执行一个查询-2

    嵌套循环算子可用于执行内连接、左外连接和联合。因为不处理整个内表,所以它不能用于其他连接类型:全连接和右连接。 Merge Join Merge Join算子也是连接2个表。...Hash和Hash Join Hash和Hash Join算子一起工作。需要2个输入集,也称为外表和内表。...创建hash表后,hash join会读取外表每一行,对连接列(从外表)进行hash,并在临时hash索引种搜索匹配值。Hash join算子可用于执行内连接、左外连接和联合。...Subquery Scan和Subplan Subquery Scan算子用于union子句;subplan用于子选择。这些算子扫描他们的输入集,将每一行添加到结果集种。...2)INTERSECT ALL:如果count(outer) > 0且count(inner) > 0 ,则将该行的n 个副本写入结果集;其中n是较大的count(outer)和count(inner)

    2.3K20

    MySQL中count(*)、count(主键id)、count(字段)和count(1)那种效率更高?「建议收藏」

    在select count(?) from t这样的查询语句里面,count(*)、count(主键id)、count(字段)和count(1)等不同用法的性能,有哪些差别。...所以,count(*)、count(主键id)和count(1) 都表示返回满足条件的结果集的总行数;而count(字段),则表示返回满足条件的数据行里面,参数“字段”不为NULL的总个数。...所以结论是: 按照效率排序的话,count(字段)count(主键id)count(1)≈count(*),所以我建议你,尽量使用count(*)。...其实,把计数放在Redis里面,不能够保证计数和MySQL表里的数据精确一致的原因,是这两个不同的存储构成的系统,不支持分布式事务,无法拿到精确一致的视图。...InnoDB引擎支持事务,我们利用好事务的原子性和隔离性,就可以简化在业务开发时的逻辑。这也是InnoDB引擎备受青睐的原因之一。

    1.9K40
    领券