您的当前位置:首页正文

SQLSERVER中的ALL、PERCENT、CUBE关键字、ROLLUP关键字和GROUPIN

2020-11-09 来源:星星旅游

SQLSERVER中的ALL、PERCENT、CUBE关键字、ROLLUP关键字和GROUPING函数 先来创建一个测试表 1 USE [ tempdb ] 2 GO 3 4 CREATE TABLE #temptb(id INT ,NAME VARCHAR ( 200 )) 5 GO 6 7 INSERT INTO [ #temptb ] ( [ id ] , [ NAME ] ) 8 SELECT 1 , ' 中国 '

SQLSERVER中的ALL、PERCENT、CUBE关键字、ROLLUP关键字和GROUPING函数

先来创建一个测试表

 1 USE [tempdb]
 2 GO
 3 
 4 CREATE TABLE #temptb(id INT ,NAME VARCHAR(200))
 5 GO
 6 
 7 INSERT INTO [#temptb] ( [id], [NAME] )
 8 SELECT 1,'中国' UNION ALL
 9 SELECT 2,'中国' UNION ALL
10 SELECT 3,'英国' UNION ALL
11 SELECT 4,'英国' UNION ALL
12 SELECT 5,'美国' UNION ALL
13 SELECT 6,'美国' UNION ALL
14 SELECT null, '法国' UNION ALL
15 SELECT 8,'法国' 
16 GO
17 
18 SELECT * FROM [#temptb]
19 GO


先来看一下SELECT语句的语法:

1 SELECT [ ALL | DISTINCT ] [ topSubclause ] aliasedExpr 
2 [{ , aliasedExpr }] FROM fromClause [ WHERE whereClause ] [ GROUP BY groupByClause [ HAVING havingClause ] ] [ ORDER BY orderByClause ]
3 or
4 SELECT VALUE [ ALL | DISTINCT ] [ topSubclause ] expr FROM fromClause [ WHERE whereClause ] [ GROUP BY groupByClause [ HAVING havingClause ] ] [ ORDER BY orderByClause

ALL关键字:指定在结果集中可以显示重复的行,这是默认的关键字,也就是说,当您在查询中不使用ALL关键字,默认都已经附加上了ALL这个关键字

例如下面两个SQL语句,实际上是等价的,都会把重复的记录select出来

1 --这两个语句是等价的
2 SELECT * FROM [#temptb]
3 GO
4 -------------------------------------------
5 SELECT ALL * FROM [#temptb]
6 GO

如果您需要把唯一值select出来,过滤掉那些重复值需要使用DISTINCT关键字

1 SELECT DISTINCT([NAME]) FROM [#temptb]

而当您把SQL语句,字段放在ALL括号中,这时候就会变成一个表达式,例如下面SQL语句

1 SELECT ALL([NAME]+'您好') AS '国别' FROM [#temptb]

处理表重复记录(查询和删除)

在Name相同ID最大的记录,其中有一个SQL语句

1 SELECT *
2 FROM [#temptb] a
3 WHERE ID! ( SELECT ID
4 FROM [#temptb]
5 WHERE Name = a.Name )

如果去掉ALL关键字会怎样呢?

因为子查询需要的是一个表达式,所以需要使用ALL关键字把他变为一个表达式,所以要用ALL

ALL关键字还可以放在GROUP BY 之后

这里要分两种情况,一种是SQL语句中有where子句的的,另一种是SQL语句中没有where子句的

情况一:

1 SELECT AVG(id) FROM [#temptb] WHERE NAME='法国' GROUP BY ALL NAME
2 SELECT AVG(id) FROM [#temptb] WHERE NAME='法国' GROUP BY NAME

对于没有符合条件的行的组,这里是没有符合name='法国',作为聚合值的列值为NULL

如果没有ALL关键字,GROUP BY子句将不显示没有符合条件的行的组

情况二:

1 SELECT AVG(id) FROM [#temptb] GROUP BY ALL NAME
2 SELECT AVG(id) FROM [#temptb] GROUP BY NAME

当SQL语句中没有where子句的时候,查询出来的结果都是一样的

ALL关键字还可以放在UNION之后

1 USE [GPOSDB]
2 GO
3 INSERT INTO [dbo].[SystemPara] ( [ParaValue], [Name], [Description] )
4 SELECT 'nihao','nihao','nihao' UNION ALL
5 SELECT 'nihao','nihao','nihao' 


PERCENT关键字

PERCENT关键字需要跟TOP 关键字一起使用

从结果集中输出百分之N行,n必须是介于0~100之间的整数

1 SELECT TOP 10 PERCENT * from [#temptb]
2 GO


上面的SQL语句意思是:从[#temptb]表中输出10%的记录数,因为没有使用order by子句,所以这条记录是随机的

因为[#temptb]表有8条记录,8*10%=0.8 四舍五入之后相当于一条记录

1 SELECT TOP 30 PERCENT * from [#temptb]
2 GO

8*30%=2.4 四舍五入之后相当于三条记录,SQLSERVER在这里就算四舍五入不足三条记录,他也会输出偏大的数,也就是三条记录


CUBE关键字

CUBE关键字:如果需要在结果集内不仅包含由GROUP BY提供的正常行,还包含汇总行,可以用CUBE关键字。CUBE关键字与GROUP BY一起使用

当使用CUBE关键字的时候,可以使用GROUPING函数来输出一个额外的列,当结果行是正常的行时,返回0;当结果行是汇总行时,返回1。

1 SELECT AVG(id) AS '平均值', GROUPING(NAME) AS '是否已汇总'
2 FROM [#temptb]
3 GROUP BY NAME
4 WITH CUBE

最后一行显示了GROUP BY的记录有多少行,一共有4行记录,而在汇总行(即最后一行)是否已汇总那列显示1,表示是汇总行


Grouping关键字

指示是否聚合 GROUP BY 列表中的指定列表达式。

在结果集中,如果 GROUPING 返回 1 则指示聚合;返回 0 则指示不聚合。

如果指定了 GROUP BY,则 GROUPING 只能用在 SELECT