sql server的cube操作符使用详解

幽静森林_钰

幽静森林_钰

2016-01-29 16:27

sql server的cube操作符使用详解,sql server的cube操作符使用详解
 

cube操作符
要使用cube,首先要了解group by
其实cube和rollup区别不太大,只是在基于group by 子句创建和汇总分组的可能的组合上有一定差别,
cube将返回的更多的可能组合。如果在 group by 子句中有n个列或者是有n个表达式的话,
sqlserver在结果集上会返回2的n-1次幂个可能组合。
注意:
使用cube操作符时,最多可以有10个分组表达式
在cube中不能使用all关键字
例子:
我们在数据库统计中常常要查询以下情况:
如一个定单数据库,我们要知道每个定单的每个产品数量,每个定单的所有产品数量,所有定单的某一产品数量,所有定单所有产品总量这些汇总信息。这时使用cube就十分方便了。当然不需要这么多信息或者只想知道某一具体产品、具体某一定单,某一时间关系(前,后,之间)等等具体信息的话,只需在where中限定即可
先举一个例子,是所有情况的:
一个数据库表中记载了一个产品定购情况:
现共有三种产品(1,2,3),已经下了两个定单(1,2)
sql语句:
select productid,orderid SUM(quantity) AS total FROM order GROUP BY productid,orderid WITH CUBE
ORDER BY productid,orderid
运行后得到结果:
productid   orderid   total
null          null     95                      所有定单所有产品总量
null           1       30                      定单1所有产品数量
null           2       65                      定单2所有产品数量
1             null     15                      所有定单产品1总量
1              1        5                      定单1产品1数量
1              2       10                      定单2产品1数量
2             null     35                      所有定单产品2总量
2              1       10                      定单1产品2数量
2              2       25                      定单2产品2数量 
3             null     45                      所有定单产品3总量  
3              1       15                      定单1产品3数量
3              2       30           

展开更多 50%)
分享

猜你喜欢

sql server的cube操作符使用详解

SQLServer
sql server的cube操作符使用详解

C++中点操作符和箭头操作符的使用详解

编程语言 网络编程
C++中点操作符和箭头操作符的使用详解

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

深入使用LIKE操作符

编程语言 网络编程
深入使用LIKE操作符

JavaScript操作符以及操作符优先级

Web开发
JavaScript操作符以及操作符优先级

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

PL/SQL数据类型及操作符

编程语言 网络编程
PL/SQL数据类型及操作符

equals与"=="操作符的比较

编程语言 网络编程
equals与

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

查询表主键外键信息的SQL

查询表主键外键信息的SQL

《英雄不再》操作指南及任务攻略(Wii)

《英雄不再》操作指南及任务攻略(Wii)
下拉加载更多内容 ↓