当前位置: 首页 > news >正文

count(列名) ,count(1)与count(*) 有何区别?

Mysql版本:8.0.26
可视化客户端:sql yog


文章目录

  • 一、Mysql之count函数简介
  • 二、count(列名) ,count(常量)与count(*) 有何区别?
    • 2.1 统计字段上的区别
    • 2.2 执行效率上的区别


一、Mysql之count函数简介

👉表达式

COUNT(expression)

👉描述

返回查询的记录总数,expression 参数是一个字段或者 * 号

👉举例说明

①准备表数据

在这里插入图片描述
②查询统计user表中的username字段的总记录数

代码示例如下:

SELECT COUNT(username) FROM USER;

在这里插入图片描述

💡ps:

MySQL在Windows下不区分大小写,但在Linux下默认是区分大小写。 因此,数据库名、表名、字段名,都不允许出现任何大写字母,避免节外生枝。


二、count(列名) ,count(常量)与count(*) 有何区别?

2.1 统计字段上的区别

👉区别

  • count(*)包括了所有的列,相当于行数,在统计结果的时候,不会忽略为NULL的值
  • count(常量)包括了所有的列,比如用1代表代码行,在统计结果的时候,不会忽略为NULL的值。
  • count(列名)只包括列名那一列,在统计结果的时候,会忽略列值为空(这里的空不是指空字符串或者0,而是表示null)的计数,即某个字段值为NULL时,不统计。

👉不信?请看如下案例演示

①准备表数据

在这里插入图片描述

②sql代码测试(以字段id与name举例)

  1. 使用count(*) 与 count(常量) 查询统计

    查询user表中所有的记录行数

    代码示例如下:

    a. 使用count(*)查询统计

    SELECT COUNT(*) FROM USER;
    

    在这里插入图片描述
    b. 使用count(常量)查询统计,以1为例

    SELECT COUNT(1) FROM USER;
    

    在这里插入图片描述

  2. 使用count函数统计列name与id

    代码示例如下:

    a. 使用count(name) 查询统计列name的总记录数【2条】

    SELECT COUNT(NAME) FROM USER;
    

    在这里插入图片描述

    b. 使用count(id) 查询统计列id的总记录数【4条】

    SELECT COUNT(id) FROM USER;
    

    在这里插入图片描述

why?

💡原因

从下图中表user中的数据来看,列name下有效【非NULL】的字段值共有两行,无效【为NULL】的字段值共有两条,而列id下有效【非NULL】的字段值共有四行,没有无效【为NULL】的字段值

在这里插入图片描述

2.2 执行效率上的区别

👉区别

  • 列名为主键,count(列名)会比count(1)快

  • 列名不为主键,count(1)会比count(列名)快

  • 如果表多个列并且没有主键,则 count(1) 的执行效率优于 count(*)

  • 如果有主键,则 select count(主键)的执行效率是最优的

  • 如果表只有一个字段,则 select count(*)最优


http://www.lryc.cn/news/105204.html

相关文章:

  • node.js判断元素是否包括
  • 基于SpringBoot+Vue的地方废物回收机构管理系统设计与实现(源码+LW+部署文档等)
  • 【SAP MII学习】Day01--Overview, Security Services, and Workbench
  • 枚举类常见用法,A Guide to Java Enums
  • Vue Baidu Map--vue引入百度地图
  • 使用Express部署Vue项目
  • 344.翻转字符串+387.字符串中的第一个唯一字符
  • 安装mmcv
  • 什么是服务网格?
  • 8.1作业
  • linux-安全技术
  • 如何在免费版 pycharm 中使用 github copilot (chatGPT)?
  • SSD202D-UBOOT-FDT-获取DTB
  • 【Maven】Setting文件分享
  • 使用requestAnimationFrame 实现倒计时功能js(简单秒数倒计时)
  • jenkins通过sshPut传输文件的时候,报错Permission denied的SftpException
  • 【Python】数据分析+数据挖掘——探索Pandas中的数据筛选
  • [数据集][目标检测]天牛数据集目标检测数据集VOC格式3050张
  • python_day16_设计模式
  • uniapp开发小程序-实现中间凸起的 tabbar
  • Vue引入与Vue拦截原理
  • 2023年电赛---运动目标控制与自动追踪系统(E题)OpenMV方案
  • 6G内存运行Llama2-Chinese-7B-chat模型
  • 项目经理必备-项目总体计划模板-制式文件,可直接填写使用-公司可用
  • 正则表达式系列|(以xx开头xx结尾提取、切分、替换)
  • 金融学复习博迪(第1-5章)
  • 【前端知识】React 基础巩固(三十七)——自定义connect高阶组件
  • 前端PDF导出,使用html2Canvas和jsPDF插件
  • Android 设备兼容性使用详解
  • vnc加固