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

MySQL中COUNT(*)COUNT(1)COUNT(字段名)的区别:

计数类型描述是否计算NULL值性能考虑
COUNT(*)计算包括所有列的行数是,不区分列值是否为NULL通常最优,因为不需要检查特定列的值
COUNT(1)功能上与COUNT(*)等价,计算行数是,1是一个常量,永远不为NULLCOUNT(*)性能相同,因为执行计划通常相同
COUNT(字段名)计算指定列中非NULL值的行数否,只计算非NULL值的行数可能比COUNT(*)COUNT(1)慢,特别是当检查的字段包含许多NULL值时

在大多数情况下,COUNT(*)是首选,因为它既符合SQL标准,又在性能上表现良好。
在MySQL等关系数据库管理系统中,COUNT(*)COUNT(1) 在功能上是等价的,它们之间的区别并不明显,主要体现在以下几个方面:

COUNT(*)、COUNT(1)有明显区别吗

1. 功能等价性

  • COUNT(*):计算查询结果集中的所有行数,包括所有列,不会忽略任何行,即使某些列包含NULL值。
  • COUNT(1):将1作为一个非空的常量值,对每一行进行计数。由于1永远不为NULL,因此它实际上与COUNT(*)一样计算所有行。

在现代数据库系统中,COUNT(*)COUNT(1)在执行计划中的表现通常相同,查询效率基本没有区别。

2. 语义清晰性

  • COUNT(*):语义明确,清楚地表明了计数所有行的意图,因此更受青睐。对于阅读代码的人来说,它更直观。
  • COUNT(1):虽然功能上等价于COUNT(*),但某些开发人员可能出于个人或历史原因更喜欢它的外观。然而,从语义清晰性的角度来看,COUNT(*)更胜一筹。

3. 性能差异(历史与现代数据库系统的对比)

  • 在历史上,某些旧版的数据库系统在处理COUNT(*)时,可能会去解析整行数据,而COUNT(1)可以直接统计行数,因此会有一些微小的性能差异。
  • 然而,在现代数据库系统中(如MySQL、PostgreSQL、SQL Server等),COUNT(*)COUNT(1)在性能方面处理相似。这些系统的优化器理解这两个查询本质上是在要求相同的内容:行计数。因此,性能差异可以忽略不计。

4. 使用建议

  • 在编写SQL查询时,应优先考虑代码的可读性和可维护性。COUNT(*)因其清晰和可读性通常更受推荐。
  • 除非基于对数据库优化器的深入理解或个人偏好(且这种偏好在现代数据库系统中通常不会带来性能上的显著优势),否则应使用COUNT(*)来计数行。

综上,COUNT(*)COUNT(1)在功能上是等价的,并且在现代数据库系统中性能差异可以忽略不计。

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

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

相关文章

【计算机网络层】数据链路层 :局域网和交换机

🧸安清h:个人主页 🎥个人专栏:【计算机网络】【Mybatis篇】 🚦作者简介:一个有趣爱睡觉的intp,期待和更多人分享自己所学知识的真诚大学生。 目录 🎯局域网 🚦局域网…

C# 属性(Property)

C# 属性(Property) C# 中的属性(Property)是一种用于访问和设置类或结构成员的值的特殊类型的方法。属性允许开发者以字段的形式访问方法,提供了更为安全和灵活的数据封装。在本文中,我们将深入探讨 C# 属性的概念、用途、以及如何有效地使用它们。 属性的定义 属性由…

活动预告 |【Part2】Microsoft 安全在线技术公开课:安全性、合规性和身份基础知识

课程介绍 通过参加“Microsoft 安全在线技术公开课:安全性、合规性和身份基础知识”活动提升你的技能。在本次免费的介绍性活动中,你将获得所需的安全技能和培训,以创造影响力并利用机会推动职业发展。你将了解安全性、合规性和身份的基础知…

浏览器定制 | Windows11 编译 Chromium 133.0.6885.0(截稿前Chromium最新版之编译篇[一])

序章回顾 其实,在此之前,我已经发表过如何在Windows下编译Chromium及前期环境准备的系列文章了。 那么,既然之前已然撰写过了,缘何又出这么一篇类似的文章呢? 倘若你看过我那几篇关于windows编译Chromium的系列文章…

【vue2】el-select,虚拟滚动(vue-virtual-scroller)

需求背景​​​​​​ vue2+element-ui项目中,当el-select中数据量较大时(超出5000个dom节点),会导致页面加载和渲染卡顿、el-select下拉列表延迟展开。 在现在的el-select的基础上使用分页或者虚拟列表的形式去处理大量的下拉菜单,可以保证页面的正常渲染及el-select的…

使用webrtc-streamer查看实时监控

摄像头配置(海康摄像头为例) 摄像头视频编码应改成H264格式 webrtc-streamer下载 webrtc-streamer下载地址 下载后解压出来双击运行,端口默认8000 VUE2项目引入文件 在项目静态文件“public”中需引入两个js文件“webrtcstreamer.js”与“…

Android四大组件——Activity(二)

一、Activity之间传递消息 在&#xff08;一&#xff09;中&#xff0c;我们把数据作为独立的键值对进行传递&#xff0c;那么现在把多条数据打包成一个对象进行传递&#xff1a; 1.假设有一个User类的对象&#xff0c;我们先使用putExtra进行传递 activity_demo06.xml <…

MySQL其四,各种函数,以及模拟了炸裂函数创建用户等操作

目录 一、MySQL中的函数 1、IFNULL 2、IF 3、case &#xff08;难点&#xff09; 4、exists(难) --存在的意思 二、常见的函数 1、字符串函数 2、数学函数 3、日期函数 &#xff08;使用频率不是很高&#xff09; 4、其他函数 5、关于字符集的问题 6、mysql炸裂函数…

泷羽Sec-Burp Suite自动刷漏洞-解放双手

声明&#xff01; 学习视频来自B站up主 **泷羽sec** 有兴趣的师傅可以关注一下&#xff0c;如涉及侵权马上删除文章&#xff0c;笔记只是方便各位师傅的学习和探讨&#xff0c;文章所提到的网站以及内容&#xff0c;只做学习交流&#xff0c;其他均与本人以及泷羽sec团队无关&a…

CSS在线格式化 - 加菲工具

CSS在线格式化 打开网站 加菲工具 选择“CSS在线格式化” 或者直接访问 https://www.orcc.online/tools/css 输入CSS代码&#xff0c;点击左上角的“格式化”按钮 得到格式化后的结果

[vscode] 创建erlang gen_serve 文件快捷方式

点击左下角功能按钮&#xff0c;代码片段&#xff0c;新建全局代码片段&#xff0c;然后输入自定义内容就可以 {"Erlang gen_server": {"prefix": "genserver","body": ["-module(${1:module_name}).","-behaviour(ge…

OpenGL 几何着色器高级应用

几何着色器高级应用 概念回顾 几何着色器(Geometry Shader)是 OpenGL 管线中的可选着色器阶段,位于顶点着色器(Vertex Shader) 和光栅化阶段 之间。 其核心功能是基于输入的图元(如点、线或三角形),生成新的图元,或对输入的图元进行修改。 几何着色器的执行是以图元…

机器学习:监督学习、无监督学习

1. 引言 机器学习是一种人工智能领域的技术&#xff0c;它旨在让计算机通过学习数据和模式&#xff0c;而不是明确地进行编程来完成任务。 机器学习分为监督学习、无监督学习、半监督学习、强化学习 四种。 ​ 2. 监督学习 2.1 什么是监督学习 定义&#xff1a;根据已有的数…

使用html和JavaScript实现一个简易的物业管理系统

码实现了一个简易的物业管理系统&#xff0c;主要使用了以下技术和功能&#xff1a; 1.主要技术 使用的技术&#xff1a; HTML: 用于构建网页的基本结构。包括表单、表格、按钮等元素。 CSS: 用于美化网页的外观和布局。设置字体、颜色、边距、对齐方式等样式。 JavaScript…

【threejs】创建FPS相机

原理说明 控制器是一个很麻烦的东西&#xff0c;需要创建更多的类来管理相机行为&#xff0c;并且可自定义性差&#xff0c;所以将部分控制器的功能绑定到相机上&#xff0c;可以解决这些问题&#xff0c;所以我以 FlyControls为例&#xff0c;将控制器功能绑定到相机上&#…

【Oracle11g SQL详解】创建与管理视图:`CREATE VIEW`、`ALTER VIEW` 和 `DROP VIEW`

创建与管理视图&#xff1a;CREATE VIEW、ALTER VIEW 和 DROP VIEW 视图&#xff08;View&#xff09;是 SQL 中的一种虚拟表&#xff0c;是从数据库中一个或多个表的查询结果创建的。它不存储实际数据&#xff0c;而是存储查询的定义&#xff0c;用户可以像使用表一样使用视图…

JPG 转 PDF:免费好用的在线图片转 PDF 工具

JPG 转 PDF&#xff1a;免费好用的在线图片转 PDF 工具 在日常工作和生活中&#xff0c;我们经常需要将图片转换为 PDF 格式。无论是制作电子文档、准备演示材料&#xff0c;还是整理照片集&#xff0c;将图片转换为 PDF 都是一个常见的需求。今天为大家介绍一款完全免费、无需…

C++ webrtc开发(非原生开发,linux上使用libdatachannel库)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、libdatachannel库的下载和build二、开始使用 1.2.引入库3.开始使用 总结 前言 使用c开发webrtc在互联网上留下的资料甚少&#xff0c;经过我一段时间的探…

深入理解 Apache Shiro:安全框架全解析

亲爱的小伙伴们&#x1f618;&#xff0c;在求知的漫漫旅途中&#xff0c;若你对深度学习的奥秘、JAVA 、PYTHON与SAP 的奇妙世界&#xff0c;亦或是读研论文的撰写攻略有所探寻&#x1f9d0;&#xff0c;那不妨给我一个小小的关注吧&#x1f970;。我会精心筹备&#xff0c;在…

Coturn 实战指南:WebRTC 中的 NAT 穿透利器

1. 什么是 Coturn&#xff1f; Coturn 是一种开源的 TURN(Traversal Using Relays around NAT)服务器&#xff0c;用于解决 NAT 穿透问题。它帮助客户端在受限网络环境(例如防火墙或 NAT 后面)中实现双向通信&#xff0c;常用于 WebRTC 应用、VoIP、在线游戏等场景。 2. Cotur…