关于over的用法,拜托了各位 參考:Oracle 9i 分析函数参考手册http://www.cnoug.org/viewthread.php?tid=38387 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 呵呵,楼上出手了,无话可说了看看cnoug调优板块jametong也发过一篇,都不错。另外这个叫分析函数,而不是over的用法 谢谢两位了,cnoug调优板块jametong也发过一篇这个东东怎么找啊?能告诉一下吗?谢谢了 去www.cnoug.org 查找jametong發表的貼子 原来我也问过类似的问题,今天刚好用的着: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 D02 02 102 03 202 04 302 05 402 01 502 06 602 07 702 03 502 02 1202 01 202 01 23select b,c,sum(d) e from a group by b,c得到:B C E02 01 3002 02 1302 03 702 04 302 05 402 06 602 07 7而使用分析函数得到的结果是:SELECT b, c, d, SUM(d) OVER(PARTITION BY b,c ORDER BY d) e FROM aB C E02 01 202 01 702 01 3002 02 102 02 1302 03 202 03 702 04 302 05 402 06 602 07 7结果不一样,这样看还不是很清楚,我们把d的内容也显示出来就更清楚了:SELECT b, c, d,SUM(d) OVER(PARTITION BY b,c ORDER BY d) e FROM aB C D E02 01 2 2 d=2,sum(d)=202 01 5 7 d=5,sum(d)=702 01 23 30 d=23,sum(d)=3002 02 1 1 c值不同,重新累计02 02 12 1302 03 2 202 03 5 702 04 3 302 05 4 402 06 6 602 07 7 7 oracle 10g 临时表问题 编写存储过程或触发器,完成以下要求: 判断A表中的数据在B表中的那个范围 修改程序连接数据库的连接方式 请教oracle数据导出导入问题!!!!急!!!!! 求和问题 中国移动考试 !!!(题看看这个过程该如何实现或是用程序实现) oracle数据库的奇怪问题!! 关于blob的问题 merge into 越来越慢,求教大家 救急!救急!怎样在oralce中插入长度大于4000的字符串! 如何知道一台机器上,Oracle服务器的名字?
看看cnoug调优板块jametong也发过一篇,都不错。
另外这个叫分析函数,而不是over的用法
cnoug调优板块jametong也发过一篇
这个东东怎么找啊?能告诉一下吗?谢谢了
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 23select 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