oracle Ratio_to_report的用法

Ratio_to_report函數 函數

Syntax 測試

分析函數RATIO_TO_REPORT 用來計算當前記錄的指標expr佔開窗函數over中包含記錄的全部同一指標的百分比這裏若是開窗函數的統計結果爲null或者爲0,就是說佔用比率的被除數爲0或者爲null, 則獲得的結果也爲0. spa

開窗條件query_partition_clause決定被除數的值若是用戶忽略了這個條件則計算查詢結果中全部記錄的彙總值. code

用戶不能使用其餘分析函數或者ratio_to_report做爲分析函數ratio_to_report的參數expr, 也就是說這個函數不能循環使用但咱們能夠使用其餘普通函數做爲這個分析函數的查詢結果. 遞歸

 Examples 1 資源

     下面的示例演示瞭如何計算每個員工的工資佔部門所有工資的比例. it

建立表 io

create table T_salary(
F_depart 
varchar2(20),
F_EMP 
varchar2(20),
F_salary 
integer 
);

truncate table t_salary;
-- 
插入測試數據
insert into t_salary(f_depart, f_emp, f_salary)
select '信息管理部','張三',10000 from dual
union all
select '信息管理部','李四',2000 from dual
union all
select '人力資源部','王五',3000 from dual
union all
select '人力資源部','趙六',10000 from dual;

commit;

--
查詢每一個員工佔所在部門的工資比例 table

select f_depart,f_emp,f_salary,sum(f_salary) over(partition by f_depart) sum_salary,
  ratio_to_report(f_salary) over(
partition by f_depart) ratio_salary
from t_salary;

select

--遞歸查詢員工佔所在部門的百分比以及部門所佔公司的工資比例.

select f_depart,f_emp,f_salary,g1,
   
sum(f_salary) over(partition by decode(g1, 0, f_depart,  null), g1) sum_salary,
   ratio_to_report(f_salary) over(
partition by decode(g1, 0, f_depart, null), g1) r_salary
from (      
select f_depart,
       f_emp,
       
sum(f_salary) f_salary, grouping(f_depart) + grouping(F_emp) g1
  
from t_salary
 
group by rollup(f_depart, f_emp)
 ) t

 

 

    因爲分析函數能夠使用普通函數的結果做爲expr參數因此上面的代碼又能夠整合爲下述方式.

select f_depart,
       f_emp,
       
sum(f_salary) f_salary,
       
sum(sum(f_salary)) over(partition by decode(grouping(f_depart) + grouping(F_emp), 0, f_depart, null),grouping(f_depart) + grouping(F_emp)) sum_salary,
       ratio_to_report(
sum(f_salary)) over(partition by decode(grouping(f_depart) + grouping(F_emp), 0, f_depart, null), grouping(f_depart) + grouping(F_emp)) r_salary,
       
grouping(f_depart) + grouping(F_emp) g1
  
from t_salary
 
group by rollup(f_depart, f_emp)

相關文章
相關標籤/搜索