经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » Oracle » 查看文章
Oracle分析函数FIRST_VALUE、LAST_VALUE
来源:cnblogs  作者:九命猫幺  时间:2019/7/29 9:04:40  对本文有异议

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

  1. FIRST_VALUE
  2. { (expr) [ {RESPECT | IGNORE} NULLS ]
  3. | (expr [ {RESPECT | IGNORE} NULLS ])
  4. }
  5. OVER (analytic_clause)

测试下

  1. 10:48:07 SCOTT@study> SELECT EMPNO,
  2. 10:48:15 2 DEPTNO,
  3. 10:48:15 3 SAL,
  4. 10:48:15 4 FIRST_VALUE(SAL) IGNORE NULLS OVER(PARTITION BY DEPTNO ORDER BY SAL) AS LOWEST_IN_DEPT,
  5. 10:48:15 5 FIRST_VALUE(SAL) IGNORE NULLS OVER(PARTITION BY DEPTNO ORDER BY SAL ROWS 1 PRECEDING) AS PRECEDING_IN_DEPT,
  6. 10:48:15 6 LAST_VALUE(SAL) IGNORE NULLS OVER(PARTITION BY DEPTNO ORDER BY SAL) AS HIGHEST_IN_DEPT,
  7. 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
  8. 10:48:15 8 FROM EMP;
  9.  
  10. EMPNO DEPTNO SAL LOWEST_IN_DEPT PRECEDING_IN_DEPT HIGHEST_IN_DEPT HIGHEST_IN_DEPT
  11. ---------- ---------- ---------- -------------- ----------------- --------------- ---------------
  12. 7934 10 1300 1300 1300 1300 5000
  13. 7782 10 2450 1300 1300 2450 5000
  14. 7839 10 5000 1300 2450 5000 5000
  15. 7369 20 800 800 800 800 3000
  16. 7876 20 1100 800 800 1100 3000
  17. 7566 20 2975 800 1100 2975 3000
  18. 7788 20 3000 800 2975 3000 3000
  19. 7902 20 3000 800 3000 3000 3000
  20. 7900 30 950 950 950 950 2850
  21. 7654 30 1250 950 950 1250 2850
  22. 7521 30 1250 950 1250 1250 2850
  23. 7844 30 1500 950 1250 1500 2850
  24. 7499 30 1600 950 1500 1600 2850
  25. 7698 30 2850 950 1600 2850 2850
  26.  
  27. 14 rows selected.
  28.  
  29. Elapsed: 00:00:00.00
  30. 10:48:17 SCOTT@study>

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

原文链接:http://www.cnblogs.com/yongestcat/p/11248907.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号