group by 与 partition by
来源:互联网 发布:windows whistler下载 编辑:程序博客网 时间:2024/05/08 18:02
partition by关键字是oracle中分析性函数的一部分,它和聚合函数不同的地方在于它能返回一个分组中的多条记录,而聚合函数一般只有一条反映统计值的记录,partition by用于给结果集分组,如果没有指定那么它把整个结果集作为一个分组,它有一部分函数既是聚合函数也是分析函数,比如avg、max,也有一部分是特有的,比如first、rank,除了order by子句外,分析函数在一个查询中优先级最低。至于partition by和group by谁的性能更好,要看具体情况而定,从你所举的例子而言,partition by的作用仅用于分组,那么性能可能比不上group by。
例子:
sum() over (PARTITION BY ...) 是一个分析函数。 他执行的效果跟普通的sum ...group by ...不一样,它计算组中表达式的累积和,而不是简单的和。
表a,内容如下:
B C D
02 02 1
02 03 2
02 04 3
02 05 4
02 01 5
02 06 6
02 07 7
02 03 5
02 02 12
02 01 2
02 01 23
select b,c,sum(d) e from a group by b,c
得到:
B C E
02 01 30
02 02 13
02 03 7
02 04 3
02 05 4
02 06 6
02 07 7
而使用分析函数得到的结果是:
SELECT b, c, d, SUM(d) OVER(PARTITION BY b,c ORDER BY d) e FROM a
B C E
02 01 2
02 01 7
02 01 30
02 02 1
02 02 13
02 03 2
02 03 7
02 04 3
02 05 4
02 06 6
02 07 7
结果不一样,这样看还不是很清楚,我们把d的内容也显示出来就更清楚了:
SELECT b, c, d,SUM(d) OVER(PARTITION BY b,c ORDER BY d) e FROM a
B C D E
02 01 2 2 d=2,sum(d)=2
02 01 5 7 d=5,sum(d)=7
02 01 23 30 d=23,sum(d)=30
02 02 1 1 c值不同,重新累计
02 02 12 13
02 03 2 2
02 03 5 7
02 04 3 3
02 05 4 4
02 06 6 6
02 07 7 7
- partition by与group by
- group by 与 partition by
- partition by 与group by 区别
- over partition by与group by 区别
- group by与partition by用法
- group by 与 partition by的区别
- over partition by与group by
- over partition by与group by 的区别
- over partition by与group by 的区别
- over partition by与group by 的区别
- over partition by与group by 的区别
- over partition by与group by 的区别
- over partition by与group by 的区别
- over partition by与group by 的区别
- over partition by与group by 的区别
- over partition by与group by 的区别
- over partition by与group by 的区别
- group by 和 partition by的比较
- JAVA socket Client端代码
- 自己用Swing写的一个记事本工具
- 近期关于web服务器安全问题的心得
- 由控制面板引起的一系列失误!
- WinCE电源管理
- group by 与 partition by
- VS2008增加AJAX Control Toolkit3.5支持
- 用DirectX做2D游戏的三种方法
- 10.9 信号_kill和raise函数
- 怎样修改地址栏图标
- 超过指定长度字符串自动加省略号
- 吕不韦相关
- 增益
- Android向桌面添加快捷方式,使其指向特定的网页