加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql-server – 分区By和Group By之间的SQL Server性能比较

发布时间:2020-12-12 07:07:12 所属栏目:MsSql教程 来源:网络整理
导读:虽然在SO中已经发布了一些关于Over Partition By和Group By之间差异的问题,但我没有找到关于哪个表现更好的明确结论. 我设置了一个simple scenario at SqlFiddle,其中Over(Partition By)似乎拥有更好的执行计划(但我并不熟悉它们). 表中的数据量应该改变吗?
虽然在SO中已经发布了一些关于Over Partition By和Group By之间差异的问题,但我没有找到关于哪个表现更好的明确结论.

我设置了一个simple scenario at SqlFiddle,其中Over(Partition By)似乎拥有更好的执行计划(但我并不熟悉它们).

表中的数据量应该改变吗? Over(Partition By)最终会表现得更好吗?

解决方法

窗口函数的执行计划明显不如组的执行计划(整个组按执行计划包含在窗口函数执行计划的右上角).对于group by,SQL通常比使用over子句更好地优化,但是每个都有它们的用途.例如,如果您想为每个条目输出一个行以及该组的总和,那么窗口化可能更有意义(例如A.id | B.b1 |和B.b1相比A.id).既然你没有,它实际上没有.你基本上是使用一个组,然后再次使用一个独特的,而不是仅使用该组暗示的不同.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读