当前位置: 首页 > 图文教程 > 数据库 > MSSQL > sql rollup用法 小计汇总

MSSQL
SQL Server 2005对DBA的要求是否会更高
SQL Server新库和旧库数据字典的比较
一个获取SQL Server数据字典的经典SQL语句
三个SQL视图查出所有SQL Server数据库字典
解决SQL Server连接中最为常见的错误
Browser/Server结构浏览器和服务器结构介绍
Position方式构建Browser/Server结构
VS2003创建和打开ASP.net 工程的若干问题
ASP技巧教程:认识学习codepage的属性
SQL Server日志清除的两个方法
SQL Server端口更改后的数据库连接方式
SQL Server数据库的转储设备
用OMS来实现Oracle数据备份的方法
分析SQL Server的数据转换服务
SQL Server数据库快照形成报表
EFS加密技巧让数据更安全
SQL Server 如何将直接传递查询作为表使用
解析SQL Server 2008的商业智能
SQL Server数据库30步检查安全列表
转换 SQL数据库时的疑难问题

MSSQL 中的 sql rollup用法 小计汇总


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 140 ::
收藏到网摘: n/a

rollup在oracle ,sql-server里面都有有。

这里介绍sql server2005里面的一个使用实例:

CREATE TABLE tb(province nvarchar(10),city nvarchar(10),score int)
INSERT tb SELECT '陕西','西安',3
UNION ALL SELECT '陕西','安康',4
UNION ALL SELECT '陕西','汉中',2
UNION ALL SELECT '广东','广州',5
UNION ALL SELECT '广东','珠海',2
UNION ALL SELECT '广东','东莞',3
UNION ALL SELECT '江苏','南京',6
UNION ALL SELECT '江苏','苏州',1
GO

1、 只有一个汇总

select province as 省,sum(score) as 分数 from tb group by province with rollup

结果:

广东 10
江苏 7
陕西 9
NULL 26


select case when grouping(province)=1 then '合计' else province end as 省,sum(score) as 分数 from tb group by province with rollup

结果:

广东 10
江苏 7
陕西 9
合计 26


2、两级,中间小计最后汇总

select province as 省,city as 市,sum(score) as 分数 from tb group by province,city with rollup

结果:

广东 东莞 3
广东 广州 5
广东 珠海 2
广东 NULL 10
江苏 南京 6
江苏 苏州 1
江苏 NULL 7
陕西 安康 4
陕西 汉中 2
陕西 西安 3
陕西 NULL 9
NULL NULL 26

select province as 省,city as 市,sum(score) as 分数,grouping(province) as g_p,grouping(city) as g_c from tb group by province,city with rollup


结果:

广东 东莞 3 0 0
广东 广州 5 0 0
广东 珠海 2 0 0
广东 NULL 10 0 1
江苏 南京 6 0 0
江苏 苏州 1 0 0
江苏 NULL 7 0 1
陕西 安康 4 0 0
陕西 汉中 2 0 0
陕西 西安 3 0 0
陕西 NULL 9 0 1
NULL NULL 26 1 1


select case when grouping(province)=1 then '合计' else province end 省,
case when grouping(city)=1 and grouping(province)=0 then '小计' else city end 市,
sum(score) as 分数
from tb group by province,city with rollup

结果:

广东 东莞 3
广东 广州 5
广东 珠海 2
广东 小计 10
江苏 南京 6
江苏 苏州 1
江苏 小计 7
陕西 安康 4
陕西 汉中 2
陕西 西安 3
陕西 小计 9
合计 NULL 26