您的位置:首页 > 财经 > 产业 > 重庆住建网官网_开发公司如果对外租房需要成立管理公司吗_信息流投放_公司怎么在百度上推广

重庆住建网官网_开发公司如果对外租房需要成立管理公司吗_信息流投放_公司怎么在百度上推广

2025/4/19 3:34:17 来源:https://blog.csdn.net/weixin_41826215/article/details/147198240  浏览:    关键词:重庆住建网官网_开发公司如果对外租房需要成立管理公司吗_信息流投放_公司怎么在百度上推广
重庆住建网官网_开发公司如果对外租房需要成立管理公司吗_信息流投放_公司怎么在百度上推广

在 Oracle 数据库中,COUNT(1) 和 COUNT(*) 都用于统计表中的行数,但它们的语义和性能表现存在一些细微区别。

1. 语义区别

  • COUNT(*)
    统计表中所有行的数量,包括所有列值为 NULL 的行。它直接针对表的行进行计数,不关心具体列的值。

  • COUNT(1)
    统计表中所有行的数量,同样包括所有列值为 NULL 的行。这里的 1 是常量表达式,对每一行进行求值。由于 1 永远非空,因此结果与 COUNT(*) 相同。

2. 性能区别

在 Oracle 中,两者的执行效率几乎完全相同,因为优化器会对它们进行等价处理:

  • 对于大多数场景,COUNT(*) 和 COUNT(1) 会生成相同的执行计划(如全表扫描或索引快速全扫描)。

  • 即使表中包含大量 NULL 值,两者的性能也无差异,因为 Oracle 不会因为 COUNT(*) 需要检查所有列而降低效率。

 

3. 使用建议

  • 推荐使用 COUNT(*)
    这是 SQL 标准中定义的行数统计方式,语义更明确(直接表示“统计所有行”),可读性更高。

  • 避免使用 COUNT(列名)(除非必要)
    如果使用 COUNT(列名),会跳过该列为 NULL 的行,可能导致结果与预期不符。例如:

 

4 总结

对比项COUNT(*)COUNT(1)
语义统计所有行统计所有行
性能与 COUNT(1) 相同与 COUNT(*) 相同
可读性更高(符合 SQL 标准)稍低(依赖常量表达式)
适用场景通用行数统计通用行数统计

在 Oracle 中,COUNT(*) 和 COUNT(1) 功能等价且性能一致。推荐优先使用 COUNT(*) 以提高代码可读性,避免对 COUNT(1) 的过度依赖。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com