mysql中count的区别

  1. count(1)和count(*)
    1. 从执行计划来看,count(1)和count(*)的效果是一样的
    2. 当表的数据量大些时,对表分析之后,使用count(1)还要比使用count(*)用时多
    3. 当数据量在1W以内时,count(1)会比count(*)的用时少,不过也差不多
    4. 如果count(1)是聚集索引时,那肯定是count(1)快,但是差的很小
    5. 因为count(* )会自动优化到指定到哪一个字段,所以没必要去count(1),使用count(* ),sql会帮你完成优化的
    6. 因此,在有聚集索引时count(1)和count(*)基本没有区别
  2. count(1)和count(字段)
    1. count(1)会统计表中的所有的记录数,包含字段为null的记录
    2. count(字段)会统计该字段在表中出现的次数,忽略字段为null的情况,即不统计字段为null的记录
  3. count(*)和count(1)和count(字段)的区别
    1. 执行效果上
      1. count(*)包括了所有的列,相当于行数,在统计结果的时候,不会忽略null的值
      2. count(1)用1代表代码行,在统计结果的时候,不会忽略NULL值
      3. count(字段):只包括列名的那一列,在统计结果的时候,会忽略列值为空(这里的空不是指空字符串或者0,而是表示null)的计数,即某个字段值为null时,不统计
    2. 执行效率上
      1. 列名为主键时,count(列名)会比count(1)快
      2. 列名不为主键时,count(1)会比count(列名)快
      3. 如果表多个列并且没有主键,则count(1)的执行效率优于count(*)
      4. 如果有主键,则select count(主键)的执行效率最优
      5. 如果表只有一个字段,则select count(*)最优
相关推荐
likerhood几秒前
Java的TimeUnit详细讲解
java·开发语言
2401_897190553 分钟前
【C++高阶系列】告别内查找局限:基于磁盘 I/O 视角的 B 树深度剖析与 C++ 泛型实现!
java·c++·算法
一只专注api接口开发的技术猿4 分钟前
京东商品实时监控选品实战:用 Open Claw API 快速搭建自动化工具
运维·数据库·自动化
摇滚侠5 分钟前
Java 项目教程《黑马商城》微服务拆分 20 - 22
java·分布式·架构
树下水月5 分钟前
Easyswoole 框架session在高并发/频繁请求下数据丢失问题记录
java·后端·spring
冻感糕人~7 分钟前
大模型面试干货:小白程序员如何准备,轻松拿下高薪Offer?收藏这份独家秘籍!
java·人工智能·学习·ai·面试·职场和发展·大模型学习
万事大吉CC9 分钟前
【7】Django 类视图实战指南:如何高效引用与配置
数据库·sqlite
2501_9127840814 分钟前
反向海淘系统架构设计:1688 自动代采与微服务高并发实战解析
java·微服务·系统架构
木土雨成小小测试员19 分钟前
Python测试开发之后端二完结
数据库·python·sqlite
风筝在晴天搁浅21 分钟前
字节/蚂蚁/美团/拼多多 LeetCode 165.比较版本号
java·leetcode