selectcount()和selectcount(1)的区别和执行方式讲解
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了selectcount()和selectcount(1)的区别和执行方式讲解,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2179字,纯文字阅读大概需要4分钟。
内容图文
在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数据库大小写敏感的问题
- 浅谈mysql 系统用户最大文件打开数限制
- 分组查询GROUP BY的使用与SQL执行顺序的讲解
- python使用adbapi实现MySQL数据库的异步存储
- 数据库SQL SELECT查询的工作原理
- MySQL可重复读级别能够解决幻读吗
- MySQL不同表之前的字段复制
- MySQL优化方案参考
- MySQL索引类型Normal、Unique和Full Text的讲解
- MySQL数据库存储过程和事务的区别讲解
内容总结
以上是互联网集市为您收集整理的selectcount()和selectcount(1)的区别和执行方式讲解全部内容,希望文章能够帮你解决selectcount()和selectcount(1)的区别和执行方式讲解所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。