六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 45|回复: 0

PARTITION BY的使用

[复制链接]

升级  56%

32

主题

32

主题

32

主题

秀才

Rank: 2

积分
134
 楼主| 发表于 2013-1-26 15:15:43 | 显示全部楼层 |阅读模式
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
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表