FIRST_VALUE、LAST_VALUE分析函数可以按照特定分组和排序取出组内首尾值,语法

FIRST_VALUE
{ (expr) [ {RESPECT | IGNORE} NULLS ]
| (expr [ {RESPECT | IGNORE} NULLS ])
}
OVER (analytic_clause)

测试下

10:48:07 SCOTT@study> SELECT EMPNO,
10:48:15 2 DEPTNO,
10:48:15 3 SAL,
10:48:15 4 FIRST_VALUE(SAL) IGNORE NULLS OVER(PARTITION BY DEPTNO ORDER BY SAL) AS LOWEST_IN_DEPT,
10:48:15 5 FIRST_VALUE(SAL) IGNORE NULLS OVER(PARTITION BY DEPTNO ORDER BY SAL ROWS 1 PRECEDING) AS PRECEDING_IN_DEPT,
10:48:15 6 LAST_VALUE(SAL) IGNORE NULLS OVER(PARTITION BY DEPTNO ORDER BY SAL) AS HIGHEST_IN_DEPT,
10:48:15 7 LAST_VALUE(SAL) IGNORE NULLS OVER(PARTITION BY DEPTNO ORDER BY SAL ROWS BETWEEN UNBOUNDED PRECEDING AND UNBOUNDED FOLLOWING) AS HIGHEST_IN_DEPT
10:48:15 8 FROM EMP; EMPNO DEPTNO SAL LOWEST_IN_DEPT PRECEDING_IN_DEPT HIGHEST_IN_DEPT HIGHEST_IN_DEPT
---------- ---------- ---------- -------------- ----------------- --------------- ---------------
7934 10 1300 1300 1300 1300 5000
7782 10 2450 1300 1300 2450 5000
7839 10 5000 1300 2450 5000 5000
7369 20 800 800 800 800 3000
7876 20 1100 800 800 1100 3000
7566 20 2975 800 1100 2975 3000
7788 20 3000 800 2975 3000 3000
7902 20 3000 800 3000 3000 3000
7900 30 950 950 950 950 2850
7654 30 1250 950 950 1250 2850
7521 30 1250 950 1250 1250 2850
7844 30 1500 950 1250 1500 2850
7499 30 1600 950 1500 1600 2850
7698 30 2850 950 1600 2850 2850 14 rows selected. Elapsed: 00:00:00.00
10:48:17 SCOTT@study>

LAST_VALUE的默认写法结果不符合预期,是因为默认的开窗语句"RANGE BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW",所以需要显性写出正确的开窗语句

最新文章

  1. Ceph剖析:Leader选举
  2. yii2 widget示例
  3. 关于linux中执行脚本或程序时指定的路径
  4. Java中的String、StringBuffer以及StringBuilder的用法和区别
  5. ajax 本地测试,使用Chrome 浏览器
  6. (转载)ubuntu创建、删除文件及文件夹,强制清空回收站方法
  7. Linux串口编程(转载)
  8. [转] Form表单中method="post/get'的区别
  9. C++学习笔记2——引用
  10. HTTP协议报文格式
  11. 命令版本git 分支篇-----不断更新中
  12. Java.nio-随机读写汉字
  13. Golang入门教程(十六)Goridge -高性能的 PHP-to-Golang RPC编解码器库
  14. 【前端酷站】分享一个纯 Javascript 的图表库与立体像素风制作~
  15. python列表的11种方法
  16. scrapy中自动补全url
  17. Oracle:Authid Current_User的使用
  18. 调研ANDRIOD平台的开发环境的发展演变
  19. iOS Sprite Kit教程之xcode安装以及苹果帐号绑定
  20. install ros-indigo-map-server

热门文章

  1. day5_configparser模块
  2. 怎么安装python3
  3. Kubernetes prometheus+grafana k8s 监控
  4. 搭建Dubbo Admin(五)
  5. Linux上用NAT实现上网
  6. EventBus事件总线(牛x版)
  7. luogu P2221 [HAOI2012]高速公路题解
  8. 8.19 NOIP模拟测试26(B) 嚎叫响彻在贪婪的厂房+主仆见证了 Hobo 的离别+征途堆积出友情的永恒
  9. C# HTTP系列7 HttpWebRequest.Method属性
  10. Python之threading多线程,多进程