zoukankan      html  css  js  c++  java
  • sql小计汇总 rollup用法实例分析(转)

    这里介绍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

  • 相关阅读:
    如何发现需求
    测试linux和window下 jdk最大能使用多大内存
    java获取汉字的拼音 简单版
    oracle一条sql执行导入sql文件
    oracle使用闪回功能恢复删除的表数据
    linux环境变量配置
    有两张表;使用SQL查询,查询所有的客户订单日期最新的前五条订单记录。 糖不苦
    jQuery作业 点击出弹框 糖不苦
    #{}和${}的区别是什么? 糖不苦
    在html页面中如何使用jQuery? 糖不苦
  • 原文地址:https://www.cnblogs.com/Fskjb/p/1726084.html
Copyright © 2011-2022 走看看