over不能单独使用,要和分析函数:rank(),dense_rank(),row_number()等一起使用。
row_number():会为查询出来的每一行记录生成一个序号,依次排序且不会重复,使用row_number()时必须要用到over子句选择对某一列进行排序才能生成序号。
rank():rank函数会返回结果集中每行的排名,行的排名是相关行之前的排名数加一。与row_number()不同的是,rank函数考虑到了over子句中排序字段值相同的情况,例如第1行和第2行在该列的字段值相同,那么rank函数给这两行的返回值都会是1,然后在第三行的返回值会变为3(因为1、2行有字段值相同的情况)。
dense_rank():dense_rank函数的功能与rank函数类似,但是dense_rank在生成序号时是连续的。比如在上面rank的那个例子中,如果改用dense_rank,那么第三行的返回值会变为2.
其参数: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,则是在整个公司内进行排名。
举例:sql中的over函数和row_numbert()函数配合使用,可生成行号。可对某一列的值进行排序,对于相同值的数据行进行分组排序。
执行语句:select row_number() over(order by AID DESC) as rowid,* from bb