MYSQL--count(*) 和 count(1)和count(列名)区别

  1. count(1) and count(*)
    当表的数据量大些时,对表作分析之后,使用 count(1) 还要比使用 count( ) 用时多了!
    从执行计划来看, count(1)count( ) 的效果是一样的。 但是在表做过分析之后,
    count(1) 会比 count(*) 的用时少些( 1w 以内数据量),不过差不了多少。
    如果 count(1) 是聚索引 ,id, 那肯定是 count(1) 快。但是差的很小的。
    因为 count( ), 自动会优化指定到那一个字段。所以没必要去 count(1) ,用 count( ) , sql 会
    帮你完成优化的 因此: count(1) 和 count(*) 基本没有差别!
  2. count(1) and count( 字段 )
    两者的主要区别是
    ( 1 ) count(1) 会统计表中的所有的记录数,包含字段为 null 的记录。
    ( 2 ) count( 字段 ) 会统计该字段在表中出现的次数,忽略字段为 null 的情况。即不统计
    字段为 null 的记录。
  3. count(*) 和 count(1) 和 count( 列名 ) 区别
    执行效果上:
    count(*) 包括了所有的列,相当于行数,在统计结果的时候, 不会忽略列值为 NULL
    count(1) 包括了忽略所有列,用 1 代表代码行,在统计结果的时候, 不会忽略列值为
    NULL
    count( 列名 ) 只包括列名那一列,在统计结果的时候,会忽略列值为空(这里的空不是
    只空字符串或者 0 ,而是表示 null )的计数,即某个字段值为 NULL 时,不统计。
    执行效率上:
    列名为主键, count( 列名 ) 会比 count(1)
    列名不为主键, count(1) 会比 count( 列名 )
    如果表多个列并且没有主键,则 count 1 ) 的执行效率优于 count *
    如果有主键,则 select count (主键)的执行效率是最优的
    如果表只有一个字段,则 select count * )最优。
相关推荐
Elastic 中国社区官方博客2 小时前
在 Elasticsearch 中使用 Mistral Chat completions 进行上下文工程
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
编程爱好者熊浪3 小时前
两次连接池泄露的BUG
java·数据库
南宫乘风4 小时前
基于 Flask + APScheduler + MySQL 的自动报表系统设计
python·mysql·flask
TDengine (老段)5 小时前
TDengine 字符串函数 CHAR 用户手册
java·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
qq7422349845 小时前
Python操作数据库之pyodbc
开发语言·数据库·python
姚远Oracle ACE5 小时前
Oracle 如何计算 AWR 报告中的 Sessions 数量
数据库·oracle
Dxy12393102166 小时前
MySQL的SUBSTRING函数详解与应用
数据库·mysql
码力引擎6 小时前
【零基础学MySQL】第十二章:DCL详解
数据库·mysql·1024程序员节
杨云龙UP6 小时前
【MySQL迁移】MySQL数据库迁移实战(利用mysqldump从Windows 5.7迁至Linux 8.0)
linux·运维·数据库·mysql·mssql
l1t6 小时前
利用DeepSeek辅助修改luadbi-duckdb读取DuckDB decimal数据类型
c语言·数据库·单元测试·lua·duckdb