首先,虽然我对SQL非常熟悉,但我是一个完整的Oracle noob.我有一个单一成本专栏.我需要计算总成本,总成本的百分比,然后计算百分比的运行总和.我遇到了百分比的运行总和,因为我能想到的唯一方法是使用嵌套的SUM函数,这是不允许的.
这是有效的:
SELECT cost, SUM(cost) OVER() AS total, cost / SUM(cost) OVER() AS per
FROM my_table
ORDER BY cost DESC
Run Code Online (Sandbox Code Playgroud)
这是我正在尝试做的不起作用:
SELECT cost, SUM(cost) OVER() AS total, cost / SUM(cost) OVER() AS per,
SUM(cost/SUM(cost) OVER()) OVER(cost) AS per_sum
FROM my_table
ORDER BY cost DESC
Run Code Online (Sandbox Code Playgroud)
我只是错了,或者我想做的事情是不可能的?顺便说一句,我使用的是Oracle 10g.在此先感谢您的帮助.
您不需要内联视图内部的订单,特别是因为外部选择按订单方式执行订单.此外,cost/SUM(cost)OVER()等于RATIO_TO_REPORT(cost)OVER().
一个例子:
SQL> create table my_table(cost)
2 as
3 select 10 from dual union all
4 select 20 from dual union all
5 select 5 from dual union all
6 select 50 from dual union all
7 select 60 from dual union all
8 select 40 from dual union all
9 select 15 from dual
10 /
Table created.
Run Code Online (Sandbox Code Playgroud)
您的初始查询:
SQL> SELECT cost, SUM(cost) OVER() AS total, cost / SUM(cost) OVER() AS per
2 FROM my_table
3 ORDER BY cost DESC
4 /
COST TOTAL PER
---------- ---------- ----------
60 200 .3
50 200 .25
40 200 .2
20 200 .1
15 200 .075
10 200 .05
5 200 .025
7 rows selected.
Run Code Online (Sandbox Code Playgroud)
Quassnoi的查询包含一个拼写错误:
SQL> SELECT cost, total, per, SUM(running) OVER (ORDER BY cost)
2 FROM (
3 SELECT cost, SUM(cost) OVER() AS total, cost / SUM(cost) OVER() AS per
4 FROM my_table
5 ORDER BY
6 cost DESC
7 )
8 /
SELECT cost, total, per, SUM(running) OVER (ORDER BY cost)
*
ERROR at line 1:
ORA-00904: "RUNNING": invalid identifier
Run Code Online (Sandbox Code Playgroud)
如果我纠正那个错字.它给出了正确的结果,但错误地排序(我猜):
SQL> SELECT cost, total, per, SUM(per) OVER (ORDER BY cost)
2 FROM (
3 SELECT cost, SUM(cost) OVER() AS total, cost / SUM(cost) OVER() AS per
4 FROM my_table
5 ORDER BY
6 cost DESC
7 )
8 /
COST TOTAL PER SUM(PER)OVER(ORDERBYCOST)
---------- ---------- ---------- -------------------------
5 200 .025 .025
10 200 .05 .075
15 200 .075 .15
20 200 .1 .25
40 200 .2 .45
50 200 .25 .7
60 200 .3 1
7 rows selected.
Run Code Online (Sandbox Code Playgroud)
我认为这是你正在寻找的那个:
SQL> select cost
2 , total
3 , per
4 , sum(per) over (order by cost desc)
5 from ( select cost
6 , sum(cost) over () total
7 , ratio_to_report(cost) over () per
8 from my_table
9 )
10 order by cost desc
11 /
COST TOTAL PER SUM(PER)OVER(ORDERBYCOSTDESC)
---------- ---------- ---------- -----------------------------
60 200 .3 .3
50 200 .25 .55
40 200 .2 .75
20 200 .1 .85
15 200 .075 .925
10 200 .05 .975
5 200 .025 1
7 rows selected.
Run Code Online (Sandbox Code Playgroud)
问候,Rob.
| 归档时间: |
|
| 查看次数: |
656 次 |
| 最近记录: |