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. Python 图像处理 OpenCV (4):图像算数运算以及修改颜色空间

    前文传送门: 「Python 图像处理 OpenCV (1):入门」 「Python 图像处理 OpenCV (2):像素处理与 Numpy 操作以及 Matplotlib 显示图像」 「Python ...

  2. Pyqt5_QMessageBox

    QMessageBox header:会话窗标题 info:会话窗内容 #弹出5种不同类型的消息框 reply1=QMessageBox.information(self,"title&qu ...

  3. 【C#图解教程学习笔记】第13章 委托

    13.1 什么是委托 委托是持有一个或多个方法的对象,可将一个方法传递到另一个方法. 委托是用户自定义的引用类型. 13.2 委托概述 类表示的是数据和方法的集合,而委托持有一个或多个方法,以及一系列 ...

  4. Charles截获iPhone网络请求

    Charles介绍:Charles是在Mac下常用的截取网络封包的工具,在做iOS开发时,有时为了调试与服务器端的网络通讯协议,常常需要服务端原因一起调试.有了Charles客户端人员自娱自乐了,想怎 ...

  5. [PHP学习教程 - 心得]001.偷龙转凤技巧10则(Remember Tips)

    引言:PHP当中的一些猬锁技巧,比较基础,想起就发贴总结一下,老鸟换个姿势飘过去就是. [技巧]应该属于“方法”的一个范畴,主要指对一种生活或工作方法的熟练和灵活运用.[五笔]RFAG. 话不多说,下 ...

  6. [工具-008] C#邮件发送系统

    邮件发送系统很多,但是我这边给大家展示下我最近开发的一款邮件发送系统,有参照网上的一个兄弟的界面,进行了升级,界面如下. 从界面上我们可以看到了该邮件系统有如下功能: 1)服务器的设置 2)发件人的设 ...

  7. 不可不知的辅助测试的Fiddler小技巧

    在以前的博文中,时常有分享Fiddler的一些使用技巧,今天再贴下. Fiddler抓包工具使用详解 利用Fiddler拦截接口请求并篡改数据 Fiddler使用过程中容易忽略的小技巧 Mock测试, ...

  8. bootstrap table Showing 1 to 5 of 5 rows 页码显示英文

    注意导包先后顺序bootstrap-table-zh-CN.js链接:https://cdn.bootcdn.net/ajax/libs/bootstrap-table/1.16.0/locale/b ...

  9. 16 . PythonWeb框架之Django

    Web框架简介 Web开发是Python语言应用领域的重要部分,也是目前最主要的Web开发语言之一,在其二十多年的历史中出现了数十种Web框架,比如Django.Tornado.Flask.Twist ...

  10. 使用 git add -p 整理 patch

    背景 当我们修改了代码准备提交时,本地的改动可能包含了不能提交的调试语句,还可能需要拆分成多个细粒度的 pactch. 本文将介绍如何使用 git add -p 来交互式选择代码片段,辅助整理出所需的 ...