oracle中累计求和_oracle累积求和分析函数sum over的使用

oracle sum()over函数的使用

over不能单独使用,要和分析函数:rank(),dense_rank(),row_number()等一起使用。

over函数的参数:over(partition by columnname1 order by columnname2)

含义,按columname1指定的字段进行分组排序,或者说按字段columnname1的值进行分组排序。

例如:employees表中,有两个部门的记录:department_id =10和20

select department_id,rank() over(partition by department_id order by salary) from employees   www.2cto.com

就是指在部门10中进行薪水的排名,在部门20中进行薪水排名。

如果是partition by org_id,则是在整个公司内进行排名。

-------------------------------

sum(...) over ... 的使用

根据over(...)条件的不同

使用 sum(sal) over (order by ename)... 查询员工的薪水“连续”求和;

注意over (order by ename)如果没有order by 子句,求和就不是“连续”的,

把所有的值加到一起作为一个值。体会一下不同之处:

SQL> select deptno,ename,sal,

2 sum(sal) over (order by ename) 连续求和,

3 sum(sal) over () 总和, -

你可能感兴趣的:(oracle中累计求和)