over在SQL里就什么意思
来源:互联网 发布:数据结构和算法java版 编辑:程序博客网 时间:2024/04/30 09:33
转自:http://zhidao.baidu.com/question/89856341.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和20select 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://hi.baidu.com/h520/blog/item/44351cd7b98e8cd5a144dfa6.html
- over在SQL里就什么意思
- sql生成脚本里SET ANSI_NULLS ON什么意思
- sql生成脚本里SET ANSI_NULLS ON什么意思
- sql里 a.user_id=b.o_iccard(+) 这个 "(+) " 什么意思?
- sql中!=什么意思
- SQl中“(+)”表示什么意思
- sql生成脚本里SET ANSI_NULLS ON、SET QUOTED_IDENTIFIER ON 什么意思
- oracle 里 符号" ||" 表示什么意思??
- 在WAS里输入命令,就像在DB2里输入SQL一样
- sql语句中的问号什么意思
- SQL SERVER 2008 R2 什么意思。
- sql 语句: COLLATE Chinese_PRC_CI_AS什么意思?
- sql server中,N''表示什么意思?
- sql 语句: COLLATE Chinese_PRC_CI_AS什么意思?
- sql server中,N''表示什么意思?
- sql server中,N''表示什么意思?
- sql中<>什么意思_百度知道
- 是否在公司里,老板叫你做什么,就做什么的总结
- CMD Bat 之间调用传参
- java.lang.OutOfMemoryError: PermGen space异常处理
- CFNetwork 编程指南(与流的相关操作)
- http://acm.hdu.edu.cn/showproblem.php?pid=2680&&Choose the best route
- 谈一个优秀的 CEO 的人际观是怎样的?
- over在SQL里就什么意思
- python input 与raw_input函数的区别
- hdu1700 二维旋转
- new创建对象和直接定义的区别 (
- 如果你是一个创业公司 CEO ,如何辞退一个不合适的人?
- J2ME内存优化方法
- 《PicSi的实现细节》 第0节 下载方式及使用说明
- 日常学习笔记
- CreateWindow 创建edit不能使用中文输入的解决办法