在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,如下图所示

只要在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。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

mysql count里select_select count()和select count(1)的区别和执行方式讲解相关推荐

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

    select count()和select count(1)的区别和执行方式讲解 发布时间:2020-09-06 13:26:14 来源:脚本之家 阅读:227 作者:CODETC 在SQL Serv ...

  2. [MySQL FAQ]系列 -- 为何innodb表select count(*)很慢

    innodb表不像myisam,有个内置的计数器. 1. 可以用 select count(*) from table_name where primary_key >=0 2. 或 selec ...

  3. mysql事务实现数据更新_MySql事务select for update及数据的一致性处理讲解

    MySQL中的事务,默认是自动提交的,即autocommit = 1: 但是这样的话,在某些情形中就会出现问题:比如: 如果你想一次性插入了1000条数据,mysql会commit1000次的, 如果 ...

  4. MySQL:SELECT COUNT 小结

    作者 | 翁智华 来源 | https://www.jianshu.com/p/4913fdd1e277 背景 今天团队在做线下代码评审的时候,发现同学们在代码中出现了 select count(1) ...

  5. mysql中对一个表的id建立了唯一索引,那么查询的select count(*) ,select count(1) ,select count(id),select count(列名)

    1.mysql中对一个表的id建立了唯一索引,那么查询的select count(*) ,select count(1) ,select count(id),select count(列名) 的查询结 ...

  6. 你知道select count(*)底层究竟干了啥么?

    作者:贾春生 https://blog.didiyun.com/index.php/2019/01/08/mysql-count/ "SELECT COUNT( * ) FROM T&quo ...

  7. SELECT COUNT(*) 底层究竟干了啥么?

    "SELECT COUNT( * ) FROM TABLE" 是个再常见不过的 SQL 需求了.在 MySQL 的使用规范中,我们一般使用事务引擎 InnoDB 作为(一般业务)表 ...

  8. select count(*)底层究竟干了啥么?

    转载自  select count(*)底层究竟干了啥么? "SELECT COUNT( * ) FROM t" 是个再常见不过的 SQL 需求了.在 MySQL 的使用规范中,我 ...

  9. 一文读懂 select count(*) 底层原理

    作者:贾春生 "SELECT COUNT( * ) FROM TABLE" 是个再常见不过的 SQL 需求了.在 MySQL 的使用规范中,我们一般使用事务引擎 InnoDB 作为 ...

最新文章

  1. 改进YOLO | 可能这才是用Transformer正确打开YOLO的方式吧?
  2. iOS开发- OpenGL ES屏幕截图
  3. Floyd判圈算法(Floyd's cycle detection
  4. Condition中的transferForSignal()方法的不解
  5. 关于fi dd ler 手机抓包 网卡地址地址_136w、136nw、138pnw 通过手机设置无线连接
  6. Java—Remove Deplicates from Sorted Array(顺序数组中去重位置)
  7. ssas表格模型 权限控制_如何使用DAX函数查询SSAS表格模型数据库
  8. WPF - ViewModle中关闭Window
  9. Leetcode994腐烂的橘子(宽搜)
  10. 关于TIME_WAIT重用与RFC1337
  11. 程序员必备75道逻辑思维题(附答案)之二
  12. 有限元分析基本理论问答
  13. 桌上游戏(桌面游戏)入门指南
  14. c语言从入门到弃坑,从入门到放弃?《全面战争:三国》是怎么让我半小时内弃坑的...
  15. 给大家贴一点好东东 喜欢电影的朋友请看
  16. Intel Thunderbolt 3 接口介绍
  17. PC党福音,育碧五款游戏大作登场E3 2014
  18. 压缩软件如何删除压缩包密码(zip、rar、7-zip),忘记密码如何删除密码?
  19. Go 小项目1 - 家庭收支记账软件
  20. Matplotlib输出中文显示问题

热门文章

  1. 操作系统原理,进程的基本状态,运行态,就绪态,等待态与转换模型,进程的其他状态,创建,终止,挂起与转换模型,Linux进程状态模型示例
  2. el-table样式修改
  3. error 1962:no operating system found.boot sequence will automatically repeat.
  4. SharePoint 2010文档库批量下载文档的实现
  5. 描述卷积神经网络的结构,卷积神经网络三大特点
  6. uniapp中tabbar设置报错文件查找失败,at mian.js:5
  7. 数学算法:求多个数的最小公倍数
  8. android 淘口令,淘口令解析
  9. 解析m3u8视频播放且兼容pc端
  10. VS2022软件C语言安装