group by <grouping sets(...) ><cube(...)>
GROUP BY
GROUPING SETS()
后面将还会写学习 with cube, with rollup,以及将它们转换为标准的GROUP BY的子句GROUP SET(), CUBE的用法(虽然MSSQL以后将会去掉)
这里面的大小写混淆来写不规范,以后还是习惯使用大写吧,有时是为节省宽度空间用小写,标准还是用大写SQL的关键字
--group by 子句中的cube, rollup,
--这样理解: cube立方(既然是立方,就是变多了), rollup卷起,包起来(按字面意思理解) if object_id('dbo.orders','U') is not null drop table dbo.orders;
GO
CREATE TABLE dbo.Orders
(
orderid INT NOT NULL,
orderdate DATE NOT NULL,
empid INT NOT NULL,
custid VARCHAR(5) NOT NULL,
qty INT NOT NULL,
CONSTRAINT PK_Orders PRIMARY KEY(orderid)
);
GO
INSERT INTO dbo.Orders(orderid, orderdate, empid, custid, qty)
VALUES
(30001, '', 3, 'A', 10),
(10001, '', 2, 'A', 12),
(10005, '', 1, 'B', 20),
(40001, '', 2, 'A', 40),
(10006, '', 1, 'C', 14),
(20001, '', 2, 'B', 12),
(40005, '', 3, 'A', 10),
(20002, '', 1, 'C', 20),
(30003, '', 2, 'B', 15),
(30004, '', 3, 'C', 22),
--------------------------------------------------------------------------------
--下面单个SELECT...是可以查询的,用Union联合是不可以的 , 回顾一下 union all的用法
--使用union需要3个条件: 1. 字段列数、字段列序相同 2.类型兼容 3.查询结果集中的字段名称以第1个查询结果集中的字段名称为名
select empid, sum(qty) as SumQty
from Orders
group by empid union ---下面3处union,并不准备联合,放此处,只是为再熟悉 select custid, sum(qty) as SumQty
from Orders
group by custid union select empid,custid,sum(qty) as SumQty
from Orders
group by empid,custid union select sum(qty) as SumQty
from Orders --select * from Orders
--------------------------------------------------------------------------------
--Union All 集合运行要求所有的结果集包含相同的列数,所以补充了空列(null占位)
select empid, null, sum(qty) as SumQty --select empid as empidA, null, sum(qty) as SumQty , 联合起来后的结果集将显示empidA
from Orders
group by empid union all select null, custid, sum(qty) as SumQty
from Orders
group by custid union all select empid,custid,sum(qty) as SumQty --select empid as empidB, null, sum(qty) as SumQty,即使有empidB,也会显示为empidA
from Orders
group by empid,custid union all select null, null, sum(qty) as SumQty
from Orders
--------------------------------------------------------------------------------
...... union去重, union all 不去重,以后再补充此处
--------------------------------------------------------------------------------
--上面几个Union All连接起来,结果集等价于下面的
select empid,custid,sum(qty) as SumQty
from Orders
group by ------------------------------------此处group by 的子句 grouping sets
Grouping sets
(
(empid,custid),
(empid),
(custid),
()
);
--------------------------------------------------------------------------------
-- 上面的写法,等价于: 在group by 子句中加上 cube(empid,custid),它代表了这2种情况的任意组合,标准SQL)
-- cube(a,b) <=== >包括 GROUPING SETS((a,b),(a),(b),() )
select empid,custid,sum(qty) as SumQty
from Orders
group by cube(empid,custid) ------------------------------------此处group by 的子句 cube
--------------------------------------------------------------------------------
--旧式的写法,只是有group by ... 分组,但不是作为 group by 的子句,非标准的SQL写法(以后MSSQL会去掉这种写法)
select empid,custid,sum(qty) as SumQty
from Orders
group by empid,custid
with cube
--------------------------------------------------------------------------------
--ROLLUP,与CUBE对应(认为生成所有可能的结果集),而ROLLUP(只生成单个的结果集),认为成员之间有a>b>c的层次关系
--如grouping sets((a,b,c), (a), (b), ()) <===>rollup((a), (b), (c))
select
year(orderdate) as OrderYear,
month(orderdate) as OrderMonty,
day(orderdate) as OrderDay,
sum(qty) as SumQty
from Orders
group by rollup(year(orderdate),month(orderdate),day(orderdate)) /* 参考:《SQL Server 2008宝典_第2版_刘智勇_刘径舟_编著》,有实体书,讲解还是没有老外的书细致,老外的书会有个来龙去脉
《Microsoft SQL Server 2008技术内幕 T-SQL语言基础》
《Microsoft SQL Server 2012 T-SQL Fundamentals》 */
-------------------------------------------------------------------------------- -------------------------------------------------------------------------------- -------------------------------------------------------------------------------- --------------------------------------------------------------------------------
group by <grouping sets(...) ><cube(...)>的更多相关文章
- Grouping Sets:CUBE和ROLLUP从句
在上一篇文章里我讨论了SQL Server里Grouping Sets的功能.从文中的例子可以看到,通过简单定义需要的分组集是很容易进行各自分组.但如果像从所给的列集里想要有所有可能的分布——即所谓的 ...
- SQL Server ->> GROUPING SETS, CUBE, ROLLUP, GROUPING, GROUPING_ID
在我们制作报表的时候常常需要分组聚合.多组聚合和总合.如果通过另外的T-SQL语句来聚合难免性能太差.如果通过报表工具的聚合功能虽说比使用额外的T-SQL语句性能上要好很多,不过不够干脆,还是需要先生 ...
- Group By Grouping Sets
Group by分组函数的自定义,与group by配合使用可更加灵活的对结果集进行分组,Grouping sets会对各个层级进行汇总,然后将各个层级的汇总值union all在一起,但却比单纯的g ...
- Oracle PL/SQL之GROUP BY GROUPING SETS
[转自] http://blog.csdn.net/t0nsha/article/details/6538838 使用GROUP BY GROUPING SETS相当于把需要GROUP的集合用UNIO ...
- GROUP BY GROUPING SETS 示例
--建表 create table TEst1 ( ID ), co_CODE ), T_NAME ), Money INTEGER, P_code ) ); --插入基础数据 insert into ...
- grouping sets,cube,rollup,grouping__id,group by
例1: hive -e" select type ,status ,count(1) from usr_info where pt='2015-09-14' group by type,st ...
- SQL GROUP BY GROUPING SETS,ROLLUP,CUBE(需求举例)
实现按照不同级别分组统计 关于GROUP BY 中的GROUPING SETS,ROLLUP,CUBE 从需求的角度理解会更加容易些. 需求举例: 假如一所学校只有两个系, 每个系有两个专业, 每个专 ...
- (4.6)sql2008中的group by grouping sets
最近遇到一个情况,需要在内网系统中出一个统计报表.需要根据不同条件使用多个group by语句.需要将所有聚合的数据进行UNION操作来完成不同维度的统计查看. 直到发现在SQL SERVER 200 ...
- SQL Server 之 GROUP BY、GROUPING SETS、ROLLUP、CUBE
1.创建表 Staff CREATE TABLE [dbo].[Staff]( ,) NOT NULL, ) NULL, ) NULL, ) NULL, [Money] [int] NULL, [Cr ...
随机推荐
- 微软 Build 大会发布大量开发工具与服务!编码、协作、发布,如丝般顺滑
Microsoft Build 2020开发者大会已经圆满落幕,在连续两天48小时的不间断直播中,来自全世界的开发者共赴盛宴,场面相当壮观.在这一年一度的大聚会里,微软也是诚意满满,带来了一连串的产品 ...
- 移除项目中的UIWebView
1,AFN升级4.0 2,代码中搜索UIWebView移除相关文件 3,检查库是否使用的UIWebView 参考 https://www.jianshu.com/p/3a645500d461
- AspectJ JoinPoint及ProceedingJoinPoint 简要api文档
AspectJ使用org.aspectj.lang.JoinPoint接口表示目标类连接点对象,如果是环绕增强时,使用org.aspectj.lang.ProceedingJoinPoint表示连接点 ...
- 赛艇表演 51nod提高组模拟试题
AC通道 题目描述 小明去某个地区观看赛艇比赛,这个地区共有n个城市和m条道路,每个城市都有赛艇比赛,在第i个 城市观看赛艇表演的价钱为ai, 去其他城市观看也需要支付赛艇表演的价格.任意两个城市之间 ...
- [安卓基础] 005.创建一个简单的UI
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
- Java的基本数据类型及其封装类
Java的基本数据类型及其封装类 一.8种基本数据类型 二.基本数据类型的包装类及大小 三.基本数据类型和封装类的区别 定义不同.封装类是对象,基本数据类型不是: 使用方式不同.封装类需要先new初始 ...
- 基本的sql-select语句
插入三张表: @d:/del_data.sql; @d:/hr_cre.sql; @d:/hr_popul.sql;select ...
- excel操作数据实用技能
写代码写习惯了,在做数据预处理时也总是习惯性地用python.pandas来做处理,但其实有时候根本不需要写代码,用excel也能达到目的,甚至比写代码快很多,写代码要半天,excel只要几秒钟.下面 ...
- 用java方式实现快速排序
一.基本思想 快速排序采用分治的策略,具体如下:选择一个关键值作为基准值,找到一个元素小于比基准值小的都在左边序列(一般是无序的),比基准值大的都在右边(一般是无序的).一般选用序列第一个元素作为基准 ...
- 【Linux】CentOS7安装tomcat8.5.45,这方法也太简单了吧!
1.下载tomcat https://tomcat.apache.org/download-80.cgi 选择tar.gz.下载完大概9495kb大小的压缩包 2.将文件从Windows复制到Cent ...