zoukankan      html  css  js  c++  java
  • Ssqlserver 关于Grouping sets

    sqlserver2008之后引入Grouping sets是group by的增强版本,
    Grouping sets 在遇到多个条件时,聚合是一次性从数据库中取出所有需要操作的数据,在内存中对数据库进行聚合操作并生成结果,而union all是多次扫描表,将返回结果进行union,这也就是为什么grouping sets 和union操作所返回的数据顺序不同的原因

    --开启Io
    SET STATISTICS IO ON
    --开启cpu
    SET STATISTICS TIME ON
    
    SELECT p.CustomerId,COUNT(p.Id) FROM [dbo].[CustomerPraise] p GROUP BY GROUPING sets
    (
        p.CustomerId
    )
    
    SELECT p.CustomerId,COUNT(p.Id) FROM [dbo].[CustomerPraise] p  GROUP BY p.CustomerId

    可以看到:使用union all,增加了IO的消耗,但减少对cpu和内存资源的消耗

                  使用 grouping sets 降低了对IO的消耗,但同时增加了对cpu和内存资源的消耗

    对于GROUPING SETS来说,还经常和GROUPING函数联合使用,这个函数是反映目标列是否聚合,如果聚合则返回1,否则返回0,

    GROUP BY GROUPING SETS (A,B,C) 等价与 GROUP BY A
    UNION ALL
    GROUP BY B
    UNION ALL
    GROUP BY C

  • 相关阅读:
    双机信任关系
    VCS双机原理
    VCS常用指令
    TCL数组
    TCL数据类型
    TCL列表
    TCL基本语法
    CentOS防火墙中端口的开启和关闭
    会话保持技术及原理技术
    ESN
  • 原文地址:https://www.cnblogs.com/niuzaihenmang/p/5715733.html
Copyright © 2011-2022 走看看