首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

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

所以,count(*)、count(1)和count(主键 id) 都表示返回满足条件的结果集的总行数;而 count(字段),则表示返回满足条件的数据行里面,参数“字段”不为 NULL 的总个数。...注意:count(1)执行速度比count(主键 id)快的原因:从引擎返回 id 会涉及到解析数据行,以及拷贝字段值的操作。 count(*) MySQL 执行count(*)在优化器做了专门优化。...看到这里,你会说优化器就不能自己判断一下吗,主键 id 肯定是非空的,为什么不能按照 count(*) 来处理,多么简单的优化。当然 MySQL 专门针对这个语句进行优化也不是不可以。...但是这种需要专门优化的情况太多了,而且 MySQL 已经优化过 count(*) 了,你直接使用这种语句就可以了。...性能对比结论 count(可空字段) < count(非空字段) = count(主键 id) < count(1) ≈ count(*)

2.5K30
您找到你想要的搜索结果了吗?
是的
没有找到

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

所以,count(*)、count(1)和count(主键 id) 都表示返回满足条件的结果集的总行数;而 count(字段),则表示返回满足条件的数据行里面,参数“字段”不为 NULL 的总个数。...注意:count(1)执行速度比count(主键 id)快的原因:从引擎返回 id 会涉及到解析数据行,以及拷贝字段值的操作。 count(*) MySQL 执行count(*)在优化器做了专门优化。...看到这里,你会说优化器就不能自己判断一下吗,主键 id 肯定是非空的,为什么不能按照 count(*) 来处理,多么简单的优化。当然 MySQL 专门针对这个语句进行优化也不是不可以。...但是这种需要专门优化的情况太多了,而且 MySQL 已经优化过 count(*) 了,你直接使用这种语句就可以了。...性能对比结论 count(可空字段) < count(非空字段) = count(主键 id) < count(1) ≈ count(*) 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

2.3K10

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

MySQL COUNT 函数是一个非常常用的聚合函数,它用于计算某列或某表达式在查询结果中出现的次数。...但需要注意的是,只有在表没有 WHERE 子句和 GROUP BY 子句时,才能使用这种优化方式。...除此之外,还有一个需要注意的地方,就是在某些数据库COUNT(字段) 可能比 COUNT(1) 更快。...综上所述,我们可以得出以下结论:当查询的表不存在 WHERE 子句和 GROUP BY 子句时,COUNT(*) 可能比 COUNT(主键id) 稍微快一点。...在一些数据库COUNT(字段) 可能比 COUNT(1) 更快。因此,在实际应用,我们可以根据具体的情况来选择不同的写法,从而获得更好的查询性能。

98030

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

看到这里,你一定会说,优化器就不能自己判断一下吗,主键id肯定非空啊,为什么不能按照count(*)来处理,多么简单的优化啊。 当然,MySQL专门针对这个语句进行优化,也不是不可以。...但是这种需要专门优化的情况太多了,而且MySQL已经优化过count(*)了,你直接使用这种用法就可以了。...我们提到了在不同引擎count(*)的实现方式是不一样的,也分析了用缓存系统来存储计数值存在的问题。...其实,把计数放在Redis里面,不能够保证计数和MySQL表里的数据精确一致的原因,是这两个不同的存储构成的系统,不支持分布式事务,无法拿到精确一致的视图。...而把计数值也放在MySQL,就解决了一致性视图的问题。 InnoDB引擎支持事务,我们利用好事务的原子性和隔离性,就可以简化在业务开发时的逻辑。这也是InnoDB引擎备受青睐的原因之一。

4.6K50

MySQL count(*) 比 count(1) 快?

今天有人跟我讲 MySQL count(1) 比 count(*) 快,这能忍?必须得和他掰扯掰扯。 声明:以下讨论基于 InnoDB 存储引擎,MyISAM 因为情况特殊我在文末会单独说一下。...3.2 原理分析 不知道小伙伴们有没有注意过,我们学习 MySQL 的时候,count 函数是归在聚合函数那一类的,就是 avg、sum 等,count 函数和这些归在一起,说明它也是一个聚合函数。...最后再来说说 select count(*) from user; ,这个 SQL 的特殊之处在于它被 MySQL 优化过,当 MySQL 看到 count(*) 就知道你是想统计总记录数,就会去找到一个最小的索引树去遍历...可能有小伙伴知道,MyISAM 引擎的 select count(*) from user; 操作执行起来是非常快的,那是因为 MyISAM 把表的行数直接存在磁盘中了,需要的时候直接读取出来就行了...当然,MySQL 的 MVCC 实际上是一个非常宏大的话题,松哥以后有空了再和大家详细介绍 MVCC。 好啦,现在小伙伴们懂了吧?有问题欢迎留言讨论。

1.3K10

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

看到这里,你一定会说,优化器就不能自己判断一下吗,主键id肯定非空啊,为什么不能按照count(*)来处理,多么简单的优化啊。 当然,MySQL专门针对这个语句进行优化,也不是不可以。...但是这种需要专门优化的情况太多了,而且MySQL已经优化过count(*)了,你直接使用这种用法就可以了。...我们提到了在不同引擎count(*)的实现方式是不一样的,也分析了用缓存系统来存储计数值存在的问题。...其实,把计数放在Redis里面,不能够保证计数和MySQL表里的数据精确一致的原因,是这两个不同的存储构成的系统,不支持分布式事务,无法拿到精确一致的视图。...而把计数值也放在MySQL,就解决了一致性视图的问题。 InnoDB引擎支持事务,我们利用好事务的原子性和隔离性,就可以简化在业务开发时的逻辑。这也是InnoDB引擎备受青睐的原因之一。

1.5K40

MySQL count()函数及其优化count(1),count(*),count(字段)区别

就是为了统计记录数 由SELECT返回 为了理解这个函数,让我们祭出 employee_tbl 表 所有记录 统计行的总数 计算 Zara 的记录数 注意:由于 SQL 查询对大小写不敏感,所以在 WHERE...条件,无论是写成 ZARA 还是 Zara,结果都是一样的 count(1),count(*),count(字段)区别 count(1)和count(*) 作用 都是检索表中所有记录行的数目,不论其是否包含...null值 区别 count(1)比count(*)效率高 二 . count(字段)与count(1)和count(*)的区别 count(字段)的作用是检索表的这个字段的非空行数,不统计这个字段值为...null的记录 任何情况下SELECT COUNT(1) FROM tablename是最优选择 尽量减少SELECT COUNT(*) FROM tablename WHERE COL = ‘value...’ 这种 杜绝SELECT COUNT(COL) FROM tablename WHERE COL2 = ‘value’ 的出现 如果表没有主键,那么count(1)比count(*)快 如果有主键,那么

2.6K60

MySQL WHERE 子句

昨天介绍了 MySQL 数据库使用 SELECT 语句来查询数据,同时也简单提到了MySQL WHERE 子句,今天详细讲解下。...语法 我们知道从 MySQL 表中使用 SELECT 语句来读取数据,如需有条件地从表中选取数据,可将 WHERE 子句添加到 SELECT 语句中,WHERE 子句用于在 MySQL 过滤查询结果,...WHERE 子句类似于程序语言中的 if 条件,根据 MySQL的字段值来读取指定的数据。 参数介绍完成,再介绍下操作符。...通过以上实例,我们可以看出如果想在 MySQL 数据表读取指定的数据,WHERE 子句是非常有用的。并且,使用主键来作为 WHERE 子句的条件查询是非常快速的。...如果给定的条件在表没有任何匹配的记录,那么查询不会返回任何数据。 以上内容即为 MySQL 数据库使用 WHERE 子句来查询数据的简单讲解,下期再见。

8310

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

count(1)比count()效率高。 count(字段)是检索表的该字段的非空行数,不统计这个字段值为null的记录。...任何情况下最优选择 SELECT COUNT(1) FROM tablename 尽量减少类似: SELECT COUNT(*) FROM tablename WHERE COL = 'value'...杜绝: SELECT COUNT(COL) FROM tablename WHERE COL2 = 'value' 如果表没有主键,那么count(1)比count()快 如果有主键,那么count...count(1) and count(字段) count(1) 会统计表的所有的记录数,包含字段为null 的记录 count(字段) 会统计该字段在表中出现的次数,忽略字段为null 的情况。...执行效率 列名为主键,count(列名)会比count(1)快 列名不为主键,count(1)会比count(列名)快 如果表多个列并且没有主键,则 count(1) 的执行效率优于 count()

3.3K20

MySQL COUNT(*) COUNT(1) 与 COUNT(列) 的区别

在通过 COUNT 函数统计有多少条记录时,MySQL 的 server 层会维护一个名叫 count 的变量。...那么,InnoDB 循环遍历聚簇索引(主键索引),将读取到的记录返回给 server 层,但是不会读取记录的任何字段的值,因为 COUNT 函数的参数是 1,不是字段,所以不需要读取记录的字段值。...COUNT(*) 其实等于 COUNT(0),也就是说,当你使用 COUNT(*) 时,MySQL 会将 * 参数转化为参数 0 来处理。...而当带上 WHERE 条件语句之后,MyISAM 跟 InnoDB 就没有区别了,它们都需要扫描表来进行记录个数的统计。 5.如何优化 COUNT(*)?...参考文献 MySQL 8.0 Reference Manual :: 5.3.4.8 Counting Rows 14.19.1 Aggregate Function Descriptions - mysql.com

15610

MySQLcount是怎样执行的?———count(1),count(id),count(非索引列),count(二级索引列)的分析

经常会看到这样的例子: 当你需要统计表中有多少数据的时候,会经常使用如下语句 SELECT COUNT(*) FROM demo_info;   由于聚集索引和非聚集索引的记录是一一对应的,而非聚集索引记录包含的列...如果我们使用非聚集索引执行上述查询,即统计一下非聚集索引uk_key2共有多少条记录,是比直接统计聚集索引的记录数节省很多I/O成本。所以优化器会决定使用非聚集索引uk_key2执行上述查询。...详情可见MySQL查询为什么选择使用这个索引?...——基于MySQL 8.0.22索引成本计算 分析一下执行计划 在执行上述查询时,server层会维护一个名叫count的变量,然后: server层向InnoDB要第一条记录。...由于count函数的参数是*,MySQL会将*当作常数0处理。由于0并不是NULL,server层给count变量加1。 server层向InnoDB要下一条记录。

1.4K20
领券