登录
首页 >  数据库 >  MySQL

了解 MySQL 查询优化器:COUNT(id) 与 COUNT(*)

来源:dev.to

时间:2024-07-10 10:27:59 117浏览 收藏

欢迎各位小伙伴来到golang学习网,相聚于此都是缘哈哈哈!今天我给大家带来《了解 MySQL 查询优化器:COUNT(id) 与 COUNT(*)》,这篇文章主要讲到等等知识,如果你对数据库相关的知识非常感兴趣或者正在自学,都可以关注我,我会持续更新相关文章!当然,有什么建议也欢迎在评论留言提出!一起学习!

了解 MySQL 查询优化器:COUNT(id) 与 COUNT(*)

在 MySQL 中,我们几乎每天都会使用“COUNT”函数来帮助我们计算给定查询的行数。每个开发者关于性能的最大困境是使用“COUNT(*)”还是“COUNT(id)”更好。


MySQL优化器

MySQL 优化器是 MySQL 的关键组件,负责确定执行给定 SQL 查询的最有效方式。这部分在“COUNT”最快的困境中起着关键作用。那么让我们解释一下...

我们创建“users”表,该表将在“first_name”列上有一个索引:

创建表用户(
    id int NOT NULL AUTO_INCRMENT,
    名字 varchar(256) NOT NULL,
    主键(id),
    索引 idx_first_name (first_name)
);

我们添加几行并运行以下 2 个查询:

解释 SELECT COUNT(id) FROM 用户;
解释 SELECT COUNT(*) FROM 用户;

当你运行这两个 SQL 查询时,你会注意到它们使用相同的索引,“COUNT(*)”一点也不慢,MySQL 优化器负责这一点,它会在表中找到索引,从而给出最棒的表演。在这种情况下,两个查询将以相同的速度返回数据,因为它们使用相同的索引,并且 MySQL 优化器认为该索引是最有效的。

MySQL 优化器考虑了许多有助于选择最佳索引键的参数,以便给定的查询尽快返回数据。


结论

通常建议使用“COUNT(*)”,因为它允许 MySQL 优化器选择最有效的方法,而“COUNT(column_name)”在需要仅计算非 NULL 值的情况下特别有用​​在特定的专栏中。了解 MySQL 优化器的工作原理以及如何使用索引对于实现最佳查询性能至关重要。

今天带大家了解了的相关知识,希望对你有所帮助;关于数据库的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>