SQL Server2008 程序设计 汇总 GROUP BY,WITH ROLLUP,WITH CUBE,GROUPING SETS(..)
--SQL Server2008 程序设计 汇总 GROUP BY ,WITH ROLLUP WITH CUBE GROUPING SET(..)
- /********************************************************************************
- *主题:SQL Server2008 程序设计 汇总 group by ,WITH ROLLUP WITH CUBE
- *说明:本文是个人学习的一些笔记和个人愚见
- * 有很多地方你可能觉得有异议,欢迎一起讨论
- *作者:Stephenzhou(阿蒙)
- *日期: 2012.12.5
- *Mail:szstephenzhou@163.com
- *另外:转载请著名出处。
- **********************************************************************************/
--SQL Server2008 程序设计 汇总 group by ,WITH ROLLUP WITH CUBE /********************************************************************************
*主题:SQL Server2008 程序设计 汇总 group by ,WITH ROLLUP WITH CUBE
*说明:本文是个人学习的一些笔记和个人愚见
* 有很多地方你可能觉得有异议,欢迎一起讨论 *作者:Stephenzhou(阿蒙)
*日期: 2012.12.5 *Mail:szstephenzhou@163.com
*另外:转载请著名出处。
**********************************************************************************/
以下是测试数据
- IF OBJECT_ID('Inventory') is not null
- drop table Inventory
- go
- create table Inventory(
- Store varchar(2),
- Item varchar(20),
- Color varchar(10),
- Quantity decimal
- )
- insert into Inventory values('NY','Table','Blue',124)
- insert into Inventory values('NJ','Table','Blue',100)
- insert into Inventory values('NY','Table','Red',29)
- insert into Inventory values('NJ','Table','Red',56)
- insert into Inventory values('PA','Table','Red',138)
- insert into Inventory values('NY','Table','Green',229)
- insert into Inventory values('PA','Table','Green',304)
- insert into Inventory values('NY','Chair','Blue',101)
- insert into Inventory values('NJ','Chair','Blue',22)
- insert into Inventory values('NY','Chair','Red',21)
- insert into Inventory values('NJ','Chair','Red',10)
- insert into Inventory values('PA','Chair','Red',136)
- insert into Inventory values('NJ','Sofa','Green',2)
IF OBJECT_ID('Inventory') is not null
drop table Inventory
go
create table Inventory(
Store varchar(2),
Item varchar(20),
Color varchar(10),
Quantity decimal
)
insert into Inventory values('NY','Table','Blue',124)
insert into Inventory values('NJ','Table','Blue',100)
insert into Inventory values('NY','Table','Red',29)
insert into Inventory values('NJ','Table','Red',56)
insert into Inventory values('PA','Table','Red',138)
insert into Inventory values('NY','Table','Green',229)
insert into Inventory values('PA','Table','Green',304)
insert into Inventory values('NY','Chair','Blue',101)
insert into Inventory values('NJ','Chair','Blue',22)
insert into Inventory values('NY','Chair','Red',21)
insert into Inventory values('NJ','Chair','Red',10)
insert into Inventory values('PA','Chair','Red',136)
insert into Inventory values('NJ','Sofa','Green',2)
--一般的group by
- select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
- from Inventory
- group by Item,Color
- order by Item,Color
- /*
- Item Color TotalQuantity Stores
- -------------------- ---------- --------------------------------------- -----------
- Chair Blue 123 2
- Chair Red 167 3
- Sofa Green 2 1
- Table Blue 224 2
- Table Green 533 2
- Table Red 223 3
- (6 行受影响)
- */
select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
from Inventory
group by Item,Color
order by Item,Color
/*
Item Color TotalQuantity Stores
-------------------- ---------- --------------------------------------- -----------
Chair Blue 123 2
Chair Red 167 3
Sofa Green 2 1
Table Blue 224 2
Table Green 533 2
Table Red 223 3 (6 行受影响)
*/
GROUP BY .. WITH ROLLUP
多了4个rollup行
- select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
- from Inventory
- group by Item,Color WITH ROLLUP --group by rollup(item,color)
- order by Item,Color
- /*
- Item Color TotalQuantity Stores
- -------------------- ---------- --------------------------------------- -----------
- NULL NULL 1272 13
- Chair NULL 290 5
- Chair Blue 123 2
- Chair Red 167 3
- Sofa NULL 2 1
- Sofa Green 2 1
- Table NULL 980 7
- Table Blue 224 2
- Table Green 533 2
- Table Red 223 3
- (10 行受影响)
- */
select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
from Inventory
group by Item,Color WITH ROLLUP --group by rollup(item,color)
order by Item,Color
/*
Item Color TotalQuantity Stores
-------------------- ---------- --------------------------------------- -----------
NULL NULL 1272 13
Chair NULL 290 5
Chair Blue 123 2
Chair Red 167 3
Sofa NULL 2 1
Sofa Green 2 1
Table NULL 980 7
Table Blue 224 2
Table Green 533 2
Table Red 223 3 (10 行受影响)
*/
WITH CUBE 多维数据集,多维数据集的纬度取决于分组列的数目
- select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
- from Inventory
- group by Item,Color WITH cube --group by cube(item,color)
- order by Item,Color
- /*
- Item Color TotalQuantity Stores
- -------------------- ---------- --------------------------------------- -----------
- NULL NULL 1272 13
- NULL Blue 347 4
- NULL Green 535 3
- NULL Red 390 6
- Chair NULL 290 5
- Chair Blue 123 2
- Chair Red 167 3
- Sofa NULL 2 1
- Sofa Green 2 1
- Table NULL 980 7
- Table Blue 224 2
- Table Green 533 2
- Table Red 223 3
- (13 行受影响)
- */
select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
from Inventory
group by Item,Color WITH cube --group by cube(item,color)
order by Item,Color /*
Item Color TotalQuantity Stores
-------------------- ---------- --------------------------------------- -----------
NULL NULL 1272 13
NULL Blue 347 4
NULL Green 535 3
NULL Red 390 6
Chair NULL 290 5
Chair Blue 123 2
Chair Red 167 3
Sofa NULL 2 1
Sofa Green 2 1
Table NULL 980 7
Table Blue 224 2
Table Green 533 2
Table Red 223 3 (13 行受影响) */
GROUPING SETS(..) 仅返回最高级别
- select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
- from Inventory
- group by GROUPING sets(Item,Color)
- order by Item,Color
- /*
- Item Color TotalQuantity Stores
- -------------------- ---------- --------------------------------------- -----------
- NULL Blue 347 4
- NULL Green 535 3
- NULL Red 390 6
- Chair NULL 290 5
- Sofa NULL 2 1
- Table NULL 980 7
- (6 行受影响)
- */
select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
from Inventory
group by GROUPING sets(Item,Color)
order by Item,Color /*
Item Color TotalQuantity Stores
-------------------- ---------- --------------------------------------- -----------
NULL Blue 347 4
NULL Green 535 3
NULL Red 390 6
Chair NULL 290 5
Sofa NULL 2 1
Table NULL 980 7 (6 行受影响)
*/
混合使用:
返回store最高级别和cube的两个item,color纬度所以级别组合
- select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
- from Inventory
- group by GROUPING sets(Store) ,cube(Item,color)
- order by Item,Color
- /*
- Item Color TotalQuantity Stores
- -------------------- ---------- --------------------------------------- -----------
- NULL NULL 190 5
- NULL NULL 504 5
- NULL NULL 578 3
- NULL Blue 225 2
- NULL Blue 122 2
- NULL Green 2 1
- NULL Green 229 1
- NULL Green 304 1
- NULL Red 274 2
- NULL Red 66 2
- NULL Red 50 2
- Chair NULL 32 2
- Chair NULL 122 2
- Chair NULL 136 1
- Chair Blue 101 1
- Chair Blue 22 1
- Chair Red 10 1
- Chair Red 21 1
- Chair Red 136 1
- Sofa NULL 2 1
- Sofa Green 2 1
- Table NULL 156 2
- Table NULL 382 3
- Table NULL 442 2
- Table Blue 100 1
- Table Blue 124 1
- Table Green 229 1
- Table Green 304 1
- Table Red 29 1
- Table Red 56 1
- Table Red 138 1
- (31 行受影响)
- */
select Item,Color,SUM(Quantity) as TotalQuantity,COUNT(Store) as Stores
from Inventory
group by GROUPING sets(Store) ,cube(Item,color)
order by Item,Color /*
Item Color TotalQuantity Stores
-------------------- ---------- --------------------------------------- -----------
NULL NULL 190 5
NULL NULL 504 5
NULL NULL 578 3
NULL Blue 225 2
NULL Blue 122 2
NULL Green 2 1
NULL Green 229 1
NULL Green 304 1
NULL Red 274 2
NULL Red 66 2
NULL Red 50 2
Chair NULL 32 2
Chair NULL 122 2
Chair NULL 136 1
Chair Blue 101 1
Chair Blue 22 1
Chair Red 10 1
Chair Red 21 1
Chair Red 136 1
Sofa NULL 2 1
Sofa Green 2 1
Table NULL 156 2
Table NULL 382 3
Table NULL 442 2
Table Blue 100 1
Table Blue 124 1
Table Green 229 1
Table Green 304 1
Table Red 29 1
Table Red 56 1
Table Red 138 1 (31 行受影响)
*/
转载请著名出处。 *博客地址:http://blog.csdn.net/szstephenzhou
SQL Server2008 程序设计 汇总 GROUP BY,WITH ROLLUP,WITH CUBE,GROUPING SETS(..)的更多相关文章
- [转]详解Oracle高级分组函数(ROLLUP, CUBE, GROUPING SETS)
原文地址:http://blog.csdn.net/u014558001/article/details/42387929 本文主要讲解 ROLLUP, CUBE, GROUPING SETS的主要用 ...
- 高级聚合函数rollup(),cube(),grouping sets()
rollup(),cube(),grouping sets() 上面这几个函数,是对group by分组功能做的功能扩展. a.rollup() 功能:在原结果基础上追加一行总合计记录 ...
- SQL 中GROUP BY 、ROLLUP、CUBE 关系和区别
转自:http://www.cnblogs.com/dyufei/archive/2009/11/12/2573974.html 不言自明,看SQL就完全理解了,不需要过多解释,不错,分享之: ROL ...
- GROUP BY中ROLLUP/CUBE/GROUPING/GROUPING SETS使用示例
oracle group by中rollup和cube的区别: Oracle的GROUP BY语句除了最基本的语法外,还支持ROLLUP和CUBE语句.CUBE ROLLUP 是用于统计数据的. 实验 ...
- SQL Server2008宝典 全书代码
-- ============================================= -- Create database template -- ==================== ...
- Oracle中group by 的扩展函数rollup、cube、grouping sets
Oracle的group by除了基本使用方法以外,还有3种扩展使用方法,各自是rollup.cube.grouping sets.分别介绍例如以下: 1.rollup 对数据库表emp.如果当中两个 ...
- 【转】rollup、cub、grouping sets、grouping、grouping_id在报表中的应用
摘自 http://blog.itpub.net/26977915/viewspace-734114/ 在报表语句中经常要使用各种分组汇总,rollup和cube就是常用的分组汇总方式. 第一:gro ...
- SQL Server 之 GROUP BY、GROUPING SETS、ROLLUP、CUBE
1.创建表 Staff CREATE TABLE [dbo].[Staff]( ,) NOT NULL, ) NULL, ) NULL, ) NULL, [Money] [int] NULL, [Cr ...
- 64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录
64位 SQL Server2008链接访问Oracle 过程汇总解决方法记录 经过几天不停的网上找资料,实验,终于联通了. 环境:系统:win 2008 ,SqlServer2008 R2, 连接O ...
随机推荐
- php新特性--持续更新
命名空间 在其他语言中不算新鲜事,但php是5.3.0中引入,具体定义就不复述了,其主要作用是 封装和组织相关php类 .命名空间被引入之前php主要是通过Zend方式组织代码,这种方式带来的问题是类 ...
- 关于NRW算法(Quorum算法)
在分布式系统中,冗余数据是保证可靠性的手段,因此冗余数据的一致性维护就非常重要.一般而言,一个写操作必须要对所有的冗余数据都更新完成了,才能称为成功结束.比如一份数据在5台设备上有冗余,因为不知道读数 ...
- 大话F#和C#:是否会重蹈C#失败的覆辙?
F#.net 出来有些年头儿了,将从 VS 2010 起在 .net framework 平台上以“一等公民”身份粉墨登场的它,将会给计算机科技与软件工业带来哪些悲喜剧呢? F# 将扮演一个什么角色? ...
- Python之创建单元素tuple
tuple和list一样,可以包含 0 个.1个和任意多个元素. 包含多个元素的 tuple,前面我们已经创建过了. 包含 0 个元素的 tuple,也就是空tuple,直接用 ()表示: >& ...
- ios音频视频资料--备用
视频播放 MediaPlayer.framework MPMoviePlayerViewController VS MPMoviePlayerController MPMoviePlayerViewC ...
- 学习lamda表达式
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.L ...
- 全国省市级联数据sql语句 mysql版
全国省市级联数据sql语句 mysql版 --省级 provincial create table provincial ( provincialID int, provincialName ), p ...
- BZOJ 3998 [TJOI 2015] 弦论 解题报告
这是一道后缀自动机经典题目. 对于 $t=0$ 的情况:每个节点都代表一个子串,所以我们给每个节点的 $Size$ 都记为 $1$, 对于 $t=1$ 的情况:我们只给 $last$ 节点的 $Siz ...
- 如何设置、查看以及调试core文件
http://blog.csdn.net/xiaoxiaoniaoer1/article/details/7740820 1.core文件的生成开关和大小限制--------------------- ...
- Eclipse导入git上的maven web项目 部署
1 Eclipse中导入Git的maven项目 方法1: (1)首先当然是拉代码. 在Eclipse里面有个Git Repositories Exploring.就是Git仓库,clone a git ...