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

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

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

DECLARE @xx INTSET @xx=NULLSELECT COUNT(@xx) FROM [AdventureWorks2012].[Sales].[SalesOrderHeader]

因此当你指定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。

总结

更多相关文章

  1. Android(安卓)版本兼容 — Android(安卓)6.0 和 7.0后获取Mac地
  2. android上一些方法的区别和用法的注意事项
  3. Android中的FILL_PARENT与WRAP_CONTENT的区别
  4. android 创建桌面快捷方式 、插件
  5. android源码下载方式
  6. [Android] ACTION_GET_CONTENT与ACTION_PICK的区别
  7. 创建android逐帧动画的两种方式
  8. android上一些方法的区别和用法的注意事项
  9. 【安卓笔记】android客户端与服务端交互的三种方式

随机推荐

  1. 再论javaIO之拷贝MP3(read方法返回int的原
  2. Java的Grizzly为缓冲区占用了大量内存?
  3. Kotlin:相当于KClass的getClass()。
  4. 常用设计模式学习
  5. 关于Hadoop查看进程时jps命令出现Error:
  6. Android JVM的运行过程
  7. IT十八掌作业_java基础第20天_断点续传、
  8. Java常见对象之String
  9. JVM 性能调优监控工具
  10. Java的Web项目中Web.xml配置文件元素详解