MySQL 中 count(*)、count(1) 和 count(字段名) 有什么区别?

news/2024/12/15 14:35:55/文章来源:https://www.cnblogs.com/eiffelzero/p/18607967

MySQL 中 count(*)、count(1) 和 count(字段名) 的区别

在 MySQL 中,COUNT() 函数用于统计记录数。虽然 COUNT(*)COUNT(1)COUNT(字段名) 的功能类似,但它们在执行逻辑和结果上有所不同。


1. count(*)

特点

  • 统计表中所有行的数量,包括 NULL 值。
  • 执行时不会忽略任何行。
  • 通常是统计总行数的首选方式,因为其优化程度最高。

执行原理

  • MySQL 会将 COUNT(*) 优化为统计行数操作,不需要额外读取数据内容。
  • 引擎级别的优化使其性能优于 COUNT(字段名)

适用场景

  • 统计整个表的总行数时使用。

2. count(1)

特点

  • 统计所有行的数量,同样包括 NULL 值。
  • 1 只是一个常量,与表中的具体字段无关。

执行原理

  • MySQL 会将 COUNT(1) 优化为 COUNT(*),执行时效果基本相同。
  • 逻辑上是检查每行是否存在,判断为有效行后计数。

适用场景

  • COUNT(*) 类似,但在语义上可以明确表示对行数的统计。

3. count(字段名)

特点

  • 统计指定字段非空值的行数
  • 只会统计字段值不为 NULL 的行。

执行原理

  • 查询过程中会判断该字段是否为 NULL,只有非 NULL 的行才会被计数。
  • 若字段上存在索引,则 COUNT(字段名) 可直接通过索引计算,性能较好。

适用场景

  • 当需要统计某字段非空值的数量时使用。

4. 示例

假设有一个 users 表,内容如下:

id name age
1 Alice 25
2 Bob NULL
3 NULL 30
4 Carol NULL
5 NULL 35

(1) COUNT(*)

SELECT COUNT(*) FROM users;

结果
5
说明:统计所有行数,包括 NULL

(2) COUNT(1)

SELECT COUNT(1) FROM users;

结果
5
说明:统计所有行数,与 COUNT(*) 结果一致。

(3) COUNT(name)

SELECT COUNT(name) FROM users;

结果
3
说明:统计 name 列中非 NULL 的值,结果为 3。

(4) COUNT(age)

SELECT COUNT(age) FROM users;

结果
3
说明:统计 age 列中非 NULL 的值,结果为 3。


5. 性能对比

  1. COUNT(*)COUNT(1)

    • 性能上几乎无差别,因为都由 MySQL 优化为相同的行统计操作。
    • 优先使用 COUNT(*),更直观且语义明确。
  2. COUNT(字段名)

    • 会判断字段是否为 NULL,性能可能略低于 COUNT(*)COUNT(1)
    • 如果字段上有索引,性能会更优。

6. 总结

类型 是否统计 NULL 优化程度 使用场景
COUNT(*) 最高 统计表中总行数
COUNT(1) 统计表中总行数(与 COUNT(*) 等效)
COUNT(字段名) 中等(视索引而定) 统计字段非空值的行数

推荐:

  • 默认使用 COUNT(*),语义清晰且优化程度最高。
  • 如果需要统计字段的非空值数量,使用 COUNT(字段名)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/853285.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2024-2025-1 20241417 《计算机基础与程序设计》第十二周学习总结

2024-2025-1 20241417 《计算机基础与程序设计》第十二周学习总结 作业信息这个作业属于哪个课程 <班级的链接>(如2024-2025-1-计算机基础与程序设计)这个作业要求在哪里 <作业要求的链接>2024-2025-1计算机基础与程序设计第十二周作业这个作业的目标 <复习前…

PbootCMS中如何让后台输入的换行符在前台正确显示?

在PbootCMS中,如果你在后台输入的内容中包含换行符(如 <br>),但前台显示时这些换行符被当作普通文本输出(例如显示为 <br>),你可以通过使用格式化标签来解决这个问题。具体做法是在调用内容的标签中添加 decode=1 参数。例如,如果你原本的代码是 {sort:sub…

如何在PbootCMS中获取搜索页的关键词和搜索结果数量?

在PbootCMS中,你可以通过特定的标签来获取搜索页的关键词和搜索结果的数量。以下是如何使用这些标签的详细说明和一些扩展建议:获取搜索关键词:在搜索页模板search.html中,使用标签{$get.keyword}来获取用户输入的搜索关键词。 例如:html<h1>搜索结果:{$get.keywor…

PbootCMS后台登录验证码看不清怎么办?

在使用PbootCMS时,有时会遇到后台登录验证码看不清的问题。这通常是由于PHP版本不兼容导致的。以下是如何解决这一问题的详细步骤和注意事项。问题原因分析:PHP版本不支持:验证码看不清的问题通常是由于服务器上的PHP版本不支持PbootCMS的验证码生成功能。不同版本的PHP对某…

VS2022 配置openCV方法

第一步下载opencv库解压出来这里不做过多讲解第二步配置环境变量 %path%\build\x64\vc16\bin %path%这个替换成自己的路径 然后打开项目属性设置点击VC++目录 链接器、输入、附件依赖分别添加 前面的是我自己的目录 换成你们自己目录即可 第一步添加 库目录D:\Opencv\ope…

WPF TreeView实现固定表头

1、在WPF中TreeView默认不支持固定表头的我们可以修改样式实现固定表头新建一个TreeListView类 然后继承TreeView代码如下public class TreeListView : TreeView,IDisposable{public TreeListView(){//this.Loaded += TreeListView_Loaded;//this.SizeChanged += TreeListView_…

居家徒手健身

居家徒手健身 力竭组,组间歇2min,动作变形算力竭为一组 第一天:胸+三头 动作: 宽距俯卧撑6组(胸外延) 标准俯卧撑4组胸整体 钻石俯卧撑4组(胸中缝) 板凳臂屈伸4~8组(三头) 第二天:肩 +腿 动作: 折刀俯卧撑6~10组(肩中束) 腰间俯卧撑4~6组 (肩前束) 弹力绳深蹲6组…

个人网站建站日记-集成Markdown编辑器

一次偶然的机会,我体验的到了markdown的便捷,于是乎,我就着手给我的网站闲蛋博客社区集成了Markdown,现在可以自由的切换Markdown与富文本编辑的使用了。这里我特此分享记录下安装使用的过程。 一、安装Markdown编辑器 这里我采用的是md-editor-v3编辑器,目前看来还是很好…

arbitrum 资产桥合约

资产桥的作用 Rollup 的主要流程中,实际上不包含资产桥,也就是说即使没有资产桥,L2依然能正常运行但是此时L1与L2在数据上是完全独立的两条链,L1不理解L2上的数据(L1只保存L2压缩后的数据,不理解数据),L2上也不知道L1上发生了什么(只能拿到区块高度等一些基本信息)。完…

鸿蒙NEXT开发案例:经纬度距离计算

【引言】 在鸿蒙NEXT平台上,我们可以轻松地开发出一个经纬度距离计算器,帮助用户快速计算两点之间的距离。本文将详细介绍如何在鸿蒙NEXT中实现这一功能,通过简单的用户界面和高效的计算逻辑,为用户提供便捷的服务。 【环境准备】 • 操作系统:Windows 10 • 开发工具:De…

C语言中0为假,正数和负数均为真

001、[b20223040323@admin2 test]$ ls test.c [b20223040323@admin2 test]$ cat test.c #include <stdio.h>int main(void) {int i,j,k; ## 三个变量 负数、正数和0i = -5;j = 8;k = 0;if(i){puts("xxxx");}if(j){puts("yyyy");}if(k){puts(&qu…

2024-2025-1(20241321)《计算机基础与程序设计》第十二周学习总结

这个作业属于哪个课程 <班级的链接>(2024-2025-1-计算机基础与程序设计)这个作业要求在哪里 <作业要求的链接>(2024-2025-1计算机基础与程序设计第十二周作业)这个作业的目标 <深刻学习C语言,反思一周学习,温故知新>作业正文 ... 本博客链接https://www.…