SQL语句之Over

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

https://www.cnblogs.com/xiayang/articles/1886372.html

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值