博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
sql over的作用及用法
阅读量:7164 次
发布时间:2019-06-29

本文共 1195 字,大约阅读时间需要 3 分钟。

From:http://blog.sina.com.cn/s/blog_4388a973010007lh.html

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,则是在整个公司内进行排名。

以下是个人见解:

sql中的over函数和row_numbert()函数配合使用,可生成行号。可对某一列的值进行排序,对于相同值的数据行进行分组排序。如下表:

 

执行语句:select row_number() over(order by AID DESC) as rowid,* from bb后的结果如下:

 

rowid标识行号有了,同时AID也按降序排列。AID有重复的记录,如果要删除rowid为2所对应的记录则可以:

with [a] as

(select row_number() over(order by AID desc) as rowid,* from bb)

delete from [a] where rowid=2

如果查看rowid 为5所对应的记录的信息,可以:

with [b] as

(select row_number() over(order by AID desc) as rowid,* from bb)

select * from [b] where rowid=5

注意:

over里的order只能查查询里的原始数据进行操作,不会对计算出的新值或新字段起作用。

msdn中的说法如下:

<ORDER BY 子句> 只能引用通过 FROM 子句可用的列。<ORDER BY 子句>不能与聚合窗口函数一起使用。

转载地址:http://gjmwm.baihongyu.com/

你可能感兴趣的文章
5、前后端分离跨域问题
查看>>
spring结合mybatis不用手动关闭sqlSession 原理
查看>>
XSS攻击
查看>>
程序员如何做好应聘?简历、面试和Offer
查看>>
调试Linux内核操作指南(withing kgdb)
查看>>
LDA线性判别分析原理
查看>>
上海交通大学副教授何建平:网络系统中的数据隐私—量化、分析和设计
查看>>
数据库初探(二)
查看>>
docker离线安装
查看>>
CAD转换为图片可以设置哪些格式
查看>>
orcl 自定义排序
查看>>
AES加密解密算法简介
查看>>
KVM虚拟机管理指南(纯命令行模式)
查看>>
Hibernate 一对多注解 mappedby 作用
查看>>
grub legacy练习 之 单用户模式修改root账户口令,并为grub菜单项设置密码保护功能...
查看>>
VLAN(单臂路由,三层路由功能)
查看>>
Apache Crunch:用于简化MapReduce编程的Java库
查看>>
Xinetd属性
查看>>
struts1.x下载文件
查看>>
JuniperSRX Filter-Based Forwarding
查看>>