首页 / 数据库 / MySQL / Oracle 分析函数(笔记)
分析函数是Oracle数据库在9i版本中引入并在以后版本中不断增强的新函数种类。分析函数提供好了跨行、多层次聚合引用值的能力。分析函数所展现的效果使用传统的SQL语句也能实现,但是实现方式比较复杂,效率较低。分析函数具有三个基本的组成部分:分区子句,排序子句,开窗子句。基本语法为function1 (argument1,argument2…argumentN) over([partition-by-clause] [order-by-clause] [windowing-clause]) [ROWS | RANGE] BETWEEN <Start expr> AND <End expr> <Start expr> is [NUBOUNDED PRECEDING | CURRENT ROW | n PRECEDING | n PRECEDING] <End expr> is [NUBOUNDED FOLLOWING| CURRENT ROW | n PRECEDING | n FOLLOWING] 常用函数列表以lag函数为例select zgqk flag, kind, sid, lag(sid, 1) over(partition by flag, kindorder by flag, kind) sid_lag_1 from hidden_danger_ybyhxx where userid= 717 order by flag, kind; FLAG KIND SID SID_LAG_1 1 A01 2295 1 A02 3414 1 A02 20785 3414 1 A02 2328 20785 1 A04 3412 1 A07 2297 1 A08 2332 1 A10 3420 1 A10 2298 3420 1 A10 2329 2298 1 A10 2327 2329 1 A11 2299 1 A11 3416 2299select zgqk flag, kind, sid, lag(sid, 1,sid) over(partition by flag, kindorder by flag, kind) sid_lag_1 from hidden_danger_ybyhxx where userid= 717 order by flag, kind; FLAG KIND SID SID_LAG_1 1 A01 2295 2295 1 A02 3414 3414 1 A02 20785 3414 1 A02 2328 20785 1 A04 3412 3412 1 A07 2297 2297 1 A08 2332 2332 1 A10 3420 3420 1 A10 2298 3420 1 A10 2329 2298 1 A10 2327 2329 1 A11 2299 2299 1 A11 3416 2299 1 A12 2333 2333 1 B07 7800 7800 1 B07 12595 7800特别声明 listagg函数不支持开窗子句,示例如下select listagg(sid, ",") within group(order by sid desc) sid from ( select sid from user where userid = 76298 order by sid ); SID31827,11199,9303,7901,5629,3254 Oracle函数之GREATEST函数详解实例 http://www.linuxidc.com/Linux/2014-07/103980.htmOracle函数之单行转换函数 http://www.linuxidc.com/Linux/2014-07/103979.htm生成动态前缀且自增号码的Oracle函数 http://www.linuxidc.com/Linux/2014-03/98505.htmOracle函数之Replace() http://www.linuxidc.com/Linux/2013-01/77406.htmOracle函数大全 http://www.linuxidc.com/Linux/2012-12/75875.htmOracle函数之case和decode的用法区别及性能比较 http://www.linuxidc.com/Linux/2012-08/67104.htm更多Oracle相关信息见Oracle 专题页面 http://www.linuxidc.com/topicnews.aspx?tid=12本文永久更新链接地址