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

  • 相关阅读:
    mysql标准写法及其他常见问题
    java动态代理_aop2
    java动态代理_aop
    oracle11g exp导出问题:部分表导不出来
    决策树算法学习笔记
    阿里云九折优惠码
    标准差(Standard Deviation) 和 标准误差(Standard Error)
    Pipeline 与 xargs
    【Linux运维-集群技术进阶】Nginx+Keepalived+Tomcat搭建高可用/负载均衡/动静分离的Webserver集群
    求最大连续和——dp
  • 原文地址:https://www.cnblogs.com/Fskjb/p/1726084.html
Copyright © 2011-2022 走看看