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

相关文章:

  • 2021-06-30
  • 2021-08-23
  • 2021-06-13
  • 2021-07-03
  • 2021-12-24
  • 2022-12-23
  • 2022-01-23
猜你喜欢
  • 2021-12-05
  • 2022-01-01
  • 2022-12-23
  • 2022-12-23
  • 2022-02-28
  • 2022-12-23
  • 2021-11-18
相关资源
相似解决方案