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

面试百问之count(1) 和 count(*) 区别是什么?

count(1)count(*) 是 SQL 中用于统计行数的两种常见方式,它们的区别在于统计的对象不同。

  • count(1) :这种写法中,括号里的参数并不影响最终的计算结果,常见的用法是传入一个常数值(比如1),因为它会被优化器忽略。count(1) 会统计查询结果集中非空行的数量,相当于计算满足条件的行数。

  • count(*) :这种写法中,使用通配符 * 代表所有的列,因为通配符会展开成所有的列名,并且不会受到空值的影响。count(*) 会统计查询结果集的所有行数,包括空行和非空行。

在大多数情况下,使用 count(*) 会更常见并且更高效。因为数据库引擎可以直接计算返回的行数,而无需对具体的列进行操作。另外,count(*) 可以保证返回准确的结果,即使查询中有复杂的条件或者联结操作。

相比之下,count(1)可能会稍微慢一些,因为每一行都需要进行一次参数匹配。然而,在某些特定情况下,可能会使用 count(1) 来代替 count(*) 以解决某些性能问题。这是因为 count(1) 无需展开列名,可能会减少一些开销。

总的来说,count(*) 是更常见和更通用的用法,可以直接统计查询结果的总行数。而 count(1) 则可以在一些特殊情况下提供一些性能优势。

相关文章:

  • 机器学习-决策树【手撕】
  • Ribbon负载均衡
  • C++三剑客之std::variant(二):深入剖析
  • L1-093 猜帽子游戏(Java)
  • 【Effective C++】4. 设计与声明
  • OpenKruiseGame × KubeSphere 联合发布游戏服运维控制台,推动云原生游戏落地
  • 1.24寒假集训
  • C++高精度问题
  • 【大数据精讲】全量同步与CDC增量同步方案对比
  • (2)(2.4) CRSF/ELRS Telemetry
  • 2024免费mathtype7.4.4安装注册步骤教程
  • 【AI视野·今日NLP 自然语言处理论文速览 第七十五期】Thu, 11 Jan 2024
  • 【GitHub项目推荐--微软开源的课程(Web开发课程/机器学习课程/物联网课程/数据科学课程)】【转载】
  • openssl3.2/test/certs - 004 - cross root and root cross cert
  • Hadoop安装配置HBase
  • [设计模式Java实现附plantuml源码~创建型] 对象的克隆~原型模式
  • 【196】JAVA8 用 DOM 方式的 API 解析XML文件,无需引入第三方依赖。
  • vue中使用锚点定位
  • 项目实战——Qt实现FFmpeg音视频转码器
  • Qt5.12.0 与 VS2017 在 .pro文件转.vcxproj文件
  • 国务院关税税则委:调整对原产于美国的进口商品加征关税措施
  • 广东早熟荔枝“抢滩”上海,向长三角消费者喊话:包甜,管够
  • 他站在当代思想的地平线上,眺望浪漫主义的余晖
  • 香港将展“天方奇毯”,从地毯珍品看伊斯兰艺术
  • 俄乌释放停火和谈信号,克宫:将组建“相应级别”谈判代表团
  • 浙江首个核酸药谷落子杭州,欢迎订阅《浪尖周报》第23期