您现在的位置是:网站首页> 编程资料编程资料
sql rollup用法 小计汇总_mssql2005_
2023-05-27
362人已围观
简介 sql rollup用法 小计汇总_mssql2005_
这里介绍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
结果: 广东 10 select province as 省,city as 市,sum(score) as 分数 from tb group by province,city with rollup 结果: 广东 东莞 3 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 结果: 广东 东莞 3
select case when grouping(province)=1 then '合计' else province end as 省,sum(score) as 分数 from tb group by province with rollup
江苏 7
陕西 9
合计 26
2、两级,中间小计最后汇总
广东 广州 5
广东 珠海 2
广东 NULL 10
江苏 南京 6
江苏 苏州 1
江苏 NULL 7
陕西 安康 4
陕西 汉中 2
陕西 西安 3
陕西 NULL 9
NULL NULL 26
结果:
广东 广州 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
广东 广州 5
广东 珠海 2
广东 小计 10
江苏 南京 6
江苏 苏州 1
江苏 小计 7
陕西 安康 4
陕西 汉中 2
陕西 西安 3
陕西 小计 9
合计 NULL 26
相关内容
- SQL2008中通过DBCC OPENTRAN和会话查询事务_mssql2005_
- SQL Server2005下的安全操作技巧分享_mssql2005_
- SQLServer 2008中通过DBCC OPENTRAN和会话查询事务_mssql2005_
- sqlserver 存储过程中的top+变量使用分析(downmoon)_mssql2005_
- SQL Server Management Studio Express管理器 没有导入导出数据的向导的解决方法_mssql2005_
- 解决SQL2005备份数据库.dat或bak还原时的结构错误的解决方法_mssql2005_
- SQL2005日志收缩方法_mssql2005_
- 简单实用SQL脚本Part SQLServer 2005 链接服务器_mssql2005_
- SQLServer分布式事务问题_mssql2005_
- SqlServer 2005中使用row_number()在一个查询中删除重复记录_mssql2005_
