易截截图软件、单文件、免安装、纯绿色、仅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服务器中创建链接服务器
exec sp_addlinkedserver  'srv_lnk','','SQLOLEDB','服务器名'
exec sp_addlinkedsrvlogin 'srv_lnk','false',null,'用户名','密码'
Go
--使用
select * from srv_lnk.数据库名.dbo.表名
--断开
exec sp_dropserver 'srv_lnk','droplogins' ......

Oracle DBA手记之“V$SQL视图显示结果异常的诊断”

本文节选自《Oracle DBA手记——数据库诊断案例与性能优化实践》第2章“Yangtingkun的DBA工作手记” (作者:杨廷琨)
V$SQL视图显示结果异常的诊断
有一次碰到一个很奇怪的问题,在检查会话所执行的SQL时,发现V$SQL视图中SQL_TEXT列中的数据是不正常的。
由于V$SQL是动态性能视图,里面保存的是当 ......

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语句大全(2)

在进行数据库操作时,无非就是添加、删除、修改,这得设计到一些常用的SQL语句,如下:
SQL常用命令使用方法:
(1) 数据记录筛选:
sql="select * from 数据表 where 字段名=字段值 order by 字段名 [desc]"
sql="select * from 数据表 where 字段名 like %字段值% order by 字段名 [desc]"
sql="select top 10 * fro ......

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

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