select count()和select count(1)的区别和执行方式讲解

作者:CODETC 时间:2024-01-29 03:11:31 

在SQL Server中Count(*)或者Count(1)或者Count([列])或许是最常用的聚合函数。很多人其实对这三者之间是区分不清的。本文会阐述这三者的作用,关系以及背后的原理。

往常我经常会看到一些所谓的优化建议不使用Count(* )而是使用Count(1),从而可以提升性能,给出的理由是Count( *)会带来全表扫描。而实际上如何写Count并没有区别。

Count(1)和Count(*)实际上的意思是,评估Count()中的表达式是否为NULL,如果为NULL则不计数,而非NULL则会计数。比如我们看代码1所示,在Count中指定NULL(优化器不允许显式指定NULL,因此需要赋值给变量才能指定)。


DECLARE @xx INT
SET @xx=NULL
SELECT COUNT(@xx) FROM [AdventureWorks2012].[Sales].[SalesOrderHeader]

代码清单1.Count中指定NULL,由于所有行都为NULL,则结果全不计数,显而易见,结果为0

因此当你指定Count(*) 或者Count(1)或者无论Count(‘anything')时结果都会一样,因为这些值都不为NULL,如下图所示

select count()和select count(1)的区别和执行方式讲解

只要在Count中指定非NULL表达式,结果没有任何区别

只看结果的话,Select Count(*) Select Count(1) 两着返回结果是一样的。

假如表沒有主键(Primary key), 那么count(1)比count(*)快,如果有主键的話,那主键作为count的条件时候count(主键)最快。

如果你的表只有一个字段的话那count(*)就是最快的。

count(*) 跟 count(1) 的结果一样,都包括对NULL的统计,而count(column) 是不包括NULL的统计。

1、select 1 与 select *的区别

selelct 常量 from ... 对应所有行,返回的永远只有一个值,即常量。所以正常只会用来判断是否有还是没有(比如exists子句)。而select * from ... 是返回所有行的所有列。

性能上的差异,关键看你的from和where子句。比如说如果你的where条件中可以通过索引,那显然 select 1 from ... 的性能比 select * from ... 好。

2、select sum(1)的使用

select count(*)返回所有满足条件的记录数,此时同select sum(1) 。

但是sum()可以传任意数字,负数、浮点数都可以,返回的值是传入值n*满足条件记录数m。

来源:http://www.codetc.com/article-236-1.html

标签:select,count(),count(1),区别
0
投稿

猜你喜欢

  • Python语言中的数据类型-序列

    2023-08-31 14:36:24
  • Vue3 ref构建响应式变量失效问题及解决

    2023-07-02 16:33:49
  • C# Oracle数据库操作类实例详解

    2024-01-19 07:21:29
  • Numpy 中的矩阵求逆实例

    2022-11-15 16:51:12
  • vscode 左侧扩展活动栏内容消失的问题及解决方法

    2022-01-12 04:26:35
  • 对pytorch网络层结构的数组化详解

    2023-09-02 12:10:09
  • 基于Element的组件改造的树形选择器(树形下拉框)

    2024-05-28 16:01:30
  • python获取网络图片方法及整理过程详解

    2022-10-21 19:33:20
  • 举例详解Python中循环语句的嵌套使用

    2022-11-23 05:52:07
  • 老生常谈Python进阶之装饰器

    2022-05-20 10:51:23
  • 美图秀秀web开放平台--PHP流式上传和表单上传示例分享

    2023-11-15 08:34:42
  • 解决MybatisPlus SqlServer OFFSET 分页问题

    2024-01-12 16:26:24
  • Python编程pydantic触发及访问错误处理

    2021-05-19 20:49:07
  • python使用Plotly绘图工具绘制散点图、线形图

    2022-06-24 08:11:50
  • django redis的使用方法详解

    2023-08-03 10:54:30
  • python对excel文档去重及求和的实例

    2021-09-30 03:30:35
  • [翻译]标记语言和样式手册 Chapter 8 再谈清单

    2008-01-29 13:16:00
  • vue axios 二次封装的示例代码

    2024-05-28 15:55:04
  • python使用any判断一个对象是否为空的方法

    2022-08-17 07:32:16
  • Mysql日期和时间函数大全

    2011-03-08 09:52:00
  • asp之家 网络编程 m.aspxhome.com