COUNT(*),count(1),COUNT(ALL expression),COUNT(DISTINCT expression)
创建一个测试表
IF OBJECT_ID( 'dbo.T1' , 'U'
)IS NOT NULL
BEGIN
DROP TABLE dbo.T1;
END;
GO
CREATE TABLE dbo.T1( column_1 int ,column_2 varchar(30));
GO INSERT INTO dbo.T1( column_1 , column_2 )
VALUES( 1 , '') , ( 2 , '') , ( 3 , ''); INSERT INTO dbo.T1( column_1)
VALUES(1) , (2); INSERT INTO dbo.T1( column_2)
VALUES( ''); GO
SELECT *
FROM dbo.T1;
GO
使用各种count的方式对比结果(注意只是结果,不考虑性能,以及增加索引对于性能的影响
关于下面两者性能的对比:
SQLSERVER 里SELECT COUNT(1) 和SELECT COUNT(*)哪个性能好?
SELECT COUNT(*)AS 'count(*)', COUNT(1)AS 'count(1)' , COUNT( column_1)AS column_1 , COUNT( DISTINCT column_1) AS column_1DISTINCT
FROM dbo.T1;
SELECT * FROM dbo.T1;
count(*) count(1) column_1 column_1DISTINCT
6 6 5 3
可以看到count(*) 和count(1)在结果上是一致的,都是包含NULL值合计。
COUNT(ALL expression) 即 COUNT( column_1),为非NULL值得合计
COUNT(DISTINCT expression) 即 COUNT( DISTINCT column_1), 去除重复值,去除NULL后的合计结果
可以等同于以下写法
WITH groupby_CTE( columngroup)
AS (SELECT DISTINCT column_2 AS columngroup
FROM dbo.T1
WHERE column_2 IS NOT NULL
)
SELECT COUNT( *
)
FROM groupby_CTE;
MSDN 对其解释
COUNT (Transact-SQL)
COUNT(*) 返回组中的项数。 包括 NULL 值和重复项。
COUNT(ALL expression) 对组中的每一行都计算 expression 并返回非 Null 值的数量。
COUNT(DISTINCT expression) 对组中的每一行都计算 expression 并返回唯一非 Null 值的数量。
以下是在聚合数据操作后的展现
select column_1,count(column_1) as 'countcolumn_1',count(*) as 'count(*)'
from dbo.T1
group by column_1
column_1 countcolumn_1 count(*)
NULL 0 1
1 2 2
2 2 2
3 1 1
可以看到的NULL值并没有合计。
COUNT(*),count(1),COUNT(ALL expression),COUNT(DISTINCT expression)的更多相关文章
- COUNT(*),count(1),COUNT(ALL expression),COUNT(DISTINCT expression) BY Group by
select column_2,count(column_2) as 'count(column_2)' ,count(column_1) as 'count(column_1)' ,count(*) ...
- 【mysql】count(*),count(1)与count(column)区别
https://blog.csdn.net/lzm18064126848/article/details/50491956 count(*)对行的数目进行计算,包含NULL count(column) ...
- 查找数据库中重复的值的数据,having的使用,count(1),sum等聚会函数
通过having代替where来使用count(1),sum()等函数.譬如如下数据id value1 21 32 33 53 6 可以写个语句统计value的分组 在这里,可以省略前面的sum(va ...
- entity framework 新手入门篇(3)-entity framework实现orderby,count,groupby,like,in,分页等
前面我们已经学习了entityframework的基本的增删改查,今天,我们将在EF中实现一些更加贴近于实际功能的SQL方法. 承接上面的部分,我们有一个叫做House的数据库,其中包含house表和 ...
- 关于数据库优化1——关于count(1),count(*),和count(列名)的区别,和关于表中字段顺序的问题
1.关于count(1),count(*),和count(列名)的区别 相信大家总是在工作中,或者是学习中对于count()的到底怎么用更快.一直有很大的疑问,有的人说count(*)更快,也有的人说 ...
- sql中奇怪的sum(1),sum(2),count(1),count(6),count(*):统计总数
sql的统计函数 sql统计函数有 count 统计条数,配合group用 sum 累加指定字段数值 但注意sum(1)就特殊 sum(1)等同于count(*) sum(1)统计个数,功能和coun ...
- linq-to-sql实现left join,group by,count
linq-to-sql实现left join,group by,count 用linq-to-sql实现下面的sql语句: SELECT p.ParentId, COUNT(c.ChildId) FR ...
- 原创 Hive count 多个度量指标,带有 distinct
Hive count 多个度量指标,带有 distinct ,注意点!!! 比如 select organid, ppi, count(id1) as num1, count(distinct ...
- 聚合函数:sum,count,max,avg
聚合函数:sum,count,max,avg等,一般作用于多条记录上.通过group by可以将数据对属于一组的数据起作用. SELECT region, SUM(population), SUM(a ...
随机推荐
- leetcode 题解:Remove Duplicates from Sorted Array(已排序数组去重)
题目: Given a sorted array, remove the duplicates in place such that each element appear only once and ...
- page80-栈用例-算术表达式求值
表达式由括号, 运算符和操作数(数字)组成.我们根据以下4中情况从左到右逐个将这些实体送入栈处理. (1)将操作数压入操作数栈: (2)将运算符压入运算符栈: (3)忽略左括号: (4)在遇到右括号时 ...
- 【Trie】模板(动态指针,静态数组)
摘自hackbuteer1 Trie树,又称单词查找树或键树,是一种树形结构,是一种哈希树的变种.典型应用是用于统计和排序大量的字符串(但不仅限于字符串),所以经常被搜索引擎系统用于文本词频统计.它的 ...
- Linux 内存管理子系统
一.内存管理子系统 1 . 内存管理模块 功能: 虚拟地址到物理地址的映射 32位系统访问的地址一共4G: 0-3G : 应用程序 3G+896M :直接映射 , Vmollat区,永久内存映射,固定 ...
- Matlab之画图
1.设置对数坐标 set(gca,'XScale','log','YScale','log'); 2.加网格 grid on; 3.加log对齐网格 set(gca,'XScale','log','Y ...
- Understand
快捷键: Ctrl+Shift+H 折叠 Ctrl+Alt+F 替换
- IntelliJ IDEA 集成Tomcat后找不到HttpServlet问题(2015年06月13日)
今天第一次用IntelliJ IDEA集成Tomcat做东西玩,在IntelliJ IDEA中配置好Tomcat之后,开始写Servlet,结果却找不到HttpServlet类,原因就是Intelli ...
- LINUX下查看php运行的用户
<?php echo shell_exec("id -a"); ?> 打开网页,显示 uid=2(daemon) gid=2(daemon) groups=2(daem ...
- 记录android5.0更新踩过的坑
1. service的注册必须显示注册,不能隐式注册,相关链接http://www.eoeandroid.com/thread-568853-1-1.html 现象:Service Intent mu ...
- Android之图片颜色调节
package net.hnjdzy.imagecolor; import android.os.Bundle; import android.app.Activity; import android ...