易截截图软件、单文件、免安装、纯绿色、仅160KB

SQL SERVER的分类汇总

SQL SERVER的分类汇总
SQL SERVER中使用GROUP BY对数据进行分类汇总,我们也可以使用WITH ROLLUP和WITH CUBE配合GROUP BY进行“增强”了的分类汇总,那么他们两个是如何增强GROUP BY的汇总能力的呢?
一.功能增强
1.使用WITH ROLLUP
用下面的例子说明,GROUP使用了3个分组字段:GROUP BY A, B, C WITH ROLLUP就相当于
GROUP BY A, B, C UNION ALL
GROUP BY A, B    UNION ALL
GROUP BY A       UNION ALL
GROUP BY NULL
2.使用WITH CUBE
用下面的例子说明,GROUP使用了3个分组字段:GROUP BY A, B, C WITH CUBE就相当于
GROUP BY A, B, C UNION ALL
GROUP BY A, B    UNION ALL
GROUP BY A, C    UNION ALL
GROUP BY B, C    UNION ALL
GROUP BY A       UNION ALL
GROUP BY B       UNION ALL
GROUP BY C       UNION ALL
GROUP BY NULL  
二.说明:
1.WITH ROLLUP和CUBE可以使用HAVING和GROUPING对产生的汇总行进行再次过滤。
2.GROUP BY A, B, C WITH ROLLUP/CUBE会将生成的汇总排序号,而GROUP BY/UNION ALL 却没有,只有手工ORDER BY排序了。
3.GROUP BY的字段数若不是上例的3个,其规律与上面一致。
三.举例:
DECLARE @T TABLE (大类 CHAR, 小类 CHAR, VAL INT)
INSERT INTO @T
SELECT 'A', 'B', 1 UNION ALL
SELECT 'A', 'B', 2 UNION ALL
SELECT 'A', 'C', 3 UNION ALL
SELECT 'A', 'C', 4 UNION ALL
SELECT 'D', 'B', 5 UNION ALL
SELECT 'D', 'B', 6 UNION ALL
SELECT 'D', 'C', 7 UNION ALL
SELECT 'D', 'C', 8
--使用WITH ROLLUP汇总
SELECT 大类, 小类, SUM(VAL)
from @T
GROUP BY 大类, 小类 WITH ROLLUP
/*
大类   小类              
---- ---- -----------
A    B    3
A    C    7
A    NULL 10
D    B    11
D    C    15
D    NULL 26
NULL NULL 36
*/
--WITH ROLLUP 相当于下面的UNION ALL
SELECT 大类, 小


相关文档:

SQL Server数据类型介绍


在计算机中数据有两种特征:类型和长度。所谓数据类型就是以数据的表现方式和存储方式来划分的数据的种类。
     在SQL Server 中每个变量、参数、表达式等都有数据类型。系统提供的数据类型分为几大类,如表4-2 所示。
     其中,BIGINT、 SQL_VARIANT 和TABLE 是SQL Server ......

SQL操作全集

SQL分类:
DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE)
DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT)
DCL—数据控制语言(GRANT,REVOKE,COMMIT,ROLLBACK)
首先,简要介绍基础语句:
1、说明:创建数据库
CREATE DATABASE database-name
2、说明:删除数据库
drop database db ......

SQL语句大全(1)

--语 句 功 能
--数据操作
SELECT --从数据库表中检索数据行和列
INSERT --向数据库表添加新数据行
DELETE --从数据库表中删除数据行
UPDATE --更新数据库表中的数据
--数据定义
CREATE TABLE --创建一个数据库表
DROP TABLE --从数据库中删除表
ALTER TABLE --修改数据库表结构
CREATE VIEW --创建一个视图
DRO ......

sql server模式匹配运算下的转义符

刚在看书,提到了sql server的模式匹配运算,接着想到了通配符的转义问题,因为太久没用,Google了搜索了一下才想起来,写几句话记录下。 关于通配符的转义,sql server里边提供了关键字escape来处理。但是escape本身不是什么转义符(刚才我就是在这里搞错了),而是将escape后面的符号定义为转义符。举个例: select ......
© 2009 ej38.com All Rights Reserved. 关于E健网联系我们 | 站点地图 | 赣ICP备09004571号