over语句的使用--sql
来源:互联网 发布:零基础程序员入门 编辑:程序博客网 时间:2024/06/01 23:57
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 子句>不能与聚合窗口函数一起使用。
- over语句的使用--sql
- SQL语句中的rank () over , row_number() over ,rank_dense () over
- sql语句row_number() OVER用法
- sql语句关键字over的作用及用法
- sql语句关键字over的作用及用法
- sql over函数使用
- SQL OVER的运用。
- sql Over的用法
- SQL语句中的rank () over , row_number() over ,rank_dense (), PARTITION BY
- SQL语句中的rank () over , row_number() over ,rank_dense ()
- SQL语句中的rank () over , row_number() over ,rank_dense ()
- SQL语句中的rank () over , row_number() over ,rank_dense ()
- SQL语句的使用
- sql语句的使用
- sql语句的使用
- SQL语句的使用
- SQL 语句的使用
- sql语句分页多种方式ROW_NUMBER()OVER
- 日志中如何显示.pc源文件的行数和文件名
- come on .
- 51地图导航
- Android程序员指南中文版
- Webwork防重复提交
- over语句的使用--sql
- C指针进阶-函数指针、函数名做形参
- 蓝魔rm600+ 无法开机
- 使用 SmartUpload 在jsp中上传文件
- 基本概念:同步、异步、阻塞和非阻塞
- 文本文件与二进制文件
- 自己动手做地图:Dojo中的Map控件详解
- Silverlight中的Combobox学习
- 沈君山《浮生三记》小传部分读书笔记