今天小编就为大家分享一篇关于select count()和select count(1)的区别和执行方式讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

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

总结

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

最新资讯
游戏厂商出海下半场:赚钱在欧美 赚吆喝在东南亚

游戏厂商出海下半场:赚

2018年出海成为国内众多游戏公司的“标配”。
国家人工智能开放创新平台将迎来新一轮扩围

国家人工智能开放创新

国家人工智能开放创新平台即将迎来新一轮扩围。

hg3028vip

豆瓣书店,已营业14年,62平方米,2万册书,每天固定早9点开门
“傍上”腾讯 任天堂三战中国市场

“傍上”腾讯 任天堂

时隔4个月,任天堂与腾讯的合作终于有了新消息。
首款5G手机卖出 78岁老工程师成全国首位买家

首款5G手机卖出 78岁

国内首款5G手机正式开售,在北京慈云寺苏宁易购广场5G体
直击|AcFun发布5.7亿资源UP主扶持计划 涉及七大政策

直击|AcFun发布5.7亿

此次公布UP主扶植计划,AcFun表示自己“下一站值得期待
最新文章
mysql最大连接数设置技巧总结

mysql最大连接数设置

在本篇文章里小编给大家分享了关于mysql最大连接数设
MySQL可重复读级别能够解决幻读吗

MySQL可重复读级别能

这篇文章主要给大家介绍了关于MySQL可重复读级别能否
mysql数据库太大了如何备份与还原

mysql数据库太大了如

今天小编就为大家分享一篇关于mysql数据库太大了如何
MySQL数据库大小写敏感的问题

MySQL数据库大小写敏

今天小编就为大家分享一篇关于MySQL数据库大小写敏感
MySQL索引类型Normal、Unique和Full Text的讲解

MySQL索引类型Normal

今天小编就为大家分享一篇关于MySQL索引类型Normal、U
MySQL优化方案参考

MySQL优化方案参考

今天小编就为大家分享一篇关于MySQL优化方案参考,小编