当前位置:数据库 > Oracle >>

Oracle over函数用法

Oracle over函数用法
 
rank ( ) over ( [query_partition_clause] order_by_clause )
dense_rank ( ) over( [query_partition_clause] order_by_clause )
可实现按指定的字段分组排序,对于相同分组字段的结果集进行排序,其中partition by 为分组字段,order by 指定排序字段
 
over不能单独使用,要和分析函数:rank(),dense_rank(),row_number()等一起使用。
其参数: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就是指在部门10中进行薪水的排名,在部门20中进行薪水排名。如果是partition by org_id,则是在整个公司内进行排名。
 
例:对相同code分组但title为空进行降序
先对rate进行分组再根据row_number()排序
select table1.code,row_number() over(partition by t1.code order by nvl(title,0) desc) num 
from table1 where  table1.status= 1
order by code
 
显示结果:
        code        num   
--------------------- --------
1   420000029    1
2   420000029    2
3   420000031    1
4   420000032    1
5   420000046    1
6   420000046    2
 
Oracle
MySQL
Access
SQLServer
DB2
Excel
SQLite
SYBASE
Postgres
如果你遇到数据库难题:
请访问www.zzzyk.com 试试
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,