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(...)>的更多相关文章

  1. Grouping Sets:CUBE和ROLLUP从句

    在上一篇文章里我讨论了SQL Server里Grouping Sets的功能.从文中的例子可以看到,通过简单定义需要的分组集是很容易进行各自分组.但如果像从所给的列集里想要有所有可能的分布——即所谓的 ...

  2. SQL Server ->> GROUPING SETS, CUBE, ROLLUP, GROUPING, GROUPING_ID

    在我们制作报表的时候常常需要分组聚合.多组聚合和总合.如果通过另外的T-SQL语句来聚合难免性能太差.如果通过报表工具的聚合功能虽说比使用额外的T-SQL语句性能上要好很多,不过不够干脆,还是需要先生 ...

  3. Group By Grouping Sets

    Group by分组函数的自定义,与group by配合使用可更加灵活的对结果集进行分组,Grouping sets会对各个层级进行汇总,然后将各个层级的汇总值union all在一起,但却比单纯的g ...

  4. Oracle PL/SQL之GROUP BY GROUPING SETS

    [转自] http://blog.csdn.net/t0nsha/article/details/6538838 使用GROUP BY GROUPING SETS相当于把需要GROUP的集合用UNIO ...

  5. GROUP BY GROUPING SETS 示例

    --建表 create table TEst1 ( ID ), co_CODE ), T_NAME ), Money INTEGER, P_code ) ); --插入基础数据 insert into ...

  6. 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 ...

  7. SQL GROUP BY GROUPING SETS,ROLLUP,CUBE(需求举例)

    实现按照不同级别分组统计 关于GROUP BY 中的GROUPING SETS,ROLLUP,CUBE 从需求的角度理解会更加容易些. 需求举例: 假如一所学校只有两个系, 每个系有两个专业, 每个专 ...

  8. (4.6)sql2008中的group by grouping sets

    最近遇到一个情况,需要在内网系统中出一个统计报表.需要根据不同条件使用多个group by语句.需要将所有聚合的数据进行UNION操作来完成不同维度的统计查看. 直到发现在SQL SERVER 200 ...

  9. SQL Server 之 GROUP BY、GROUPING SETS、ROLLUP、CUBE

    1.创建表 Staff CREATE TABLE [dbo].[Staff]( ,) NOT NULL, ) NULL, ) NULL, ) NULL, [Money] [int] NULL, [Cr ...

随机推荐

  1. element-ui的el-table和el-form嵌套使用表单校验

    表格中嵌套使用表单验证 表格是el-table自动获取的后台数据,每行都有el-input的验证,这样一个rules的规则就不能匹配到每一行,所以要是用动态的prop和rules规则 需求如下,要对告 ...

  2. mysql日志体系大盘点

    MySql日志文件主要包含:错误日志.慢查询日志.事务日志.二进制日志等 Mysql的日志配置可以通过命令 show global variables like '%log%'; 执行的结果如下 &q ...

  3. POJ1661

    题目链接:http://poj.org/problem?id=1661 解题思路: 离散化处理 + DP. 首先,纵坐标除了用来判断老鼠是否会摔死之外基本没用,主要考虑横坐标,只要求出在横坐标上必须走 ...

  4. JavaScript的基础语法及DOM元素和事件

    一,JavaScript是什么? 1,JavaScript简称:js,是一种浏览器解释型语言,嵌套在HTML文件中交给浏览器解释执行.主要用来实现网页的动态效果,用户交互及前后端的数据传输等. 2,J ...

  5. StreamSets使用指南

    StreamSets使用指南 最近在调研Streamsets,照猫画虎做了几个最简单的Demo鉴于网络上相关资料非常少,做个记录. 1.简介 Streamsets是一款大数据实时采集和ETL工具,可以 ...

  6. 用tarjan求LCA板子(比倍增快)

    懒!!直接转载!!!! https://solstice23.top/archives/62

  7. eatwhatApp开发实战(二)

    上期,我们做了个小app“eatwhat”,接下来每期都会为其添加新的功能.本期,我们为店铺增加添加店铺的功能. 还是先设置个布局: <RelativeLayout android:layout ...

  8. git status 命令详解

    git status命令表示:文件,文件夹在工作区,暂存区的状态,下图就是文件,文件夹三种状态: Changes to be committed: (use "git restore --s ...

  9. SDP架构初识

    实现零信任的框架主要有SDP和Google Beyondcorp模型,前者出现在乙方的安全解决方案中,后者多作为甲方落地零信任的参考.本文主要记录对SDP技术的一些初步认识. 一.SDP简介 SDP是 ...

  10. 概念辨析-Description Language还是Description Library?

    https://mp.weixin.qq.com/s/p7eyD6GkniFGHrnr8t2SZQ   概念辨析-Description Language还是Description Library? ...