sql的over函数的作用和方法

over不能单独使用,要和分析函数:rank(),dense_rank(),row_number(),ntile()(参考:https://www.cnblogs.com/shizhijie/p/9366247.html) 等一起使用。
其参数: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

posted @   shan_zhayidian  阅读(5894)  评论(4编辑  收藏  举报
编辑推荐:
· 聊一聊坑人的 C# MySql.Data SDK
· 使用 .NET Core 实现一个自定义日志记录器
· [杂谈]如何选择:Session 还是 JWT?
· 硬盘空间消失之谜:Linux 服务器存储排查与优化全过程
· JavaScript是按顺序执行的吗?聊聊JavaScript中的变量提升
阅读排行:
· 好消息,在 Visual Studio 中可以免费使用 GitHub Copilot 了!
· 工作中这样用MQ,很香!
· 使用 .NET Core 实现一个自定义日志记录器
· 没事别想不开去创业!
· 聊一聊坑人的 C# MySql.Data SDK
点击右上角即可分享
微信分享提示