分析函数是oracle数据库在9i版本中引入并在以后版本中不断增强的新函数种类。分析函数提供好了跨行、多层次聚合引用值的能力。分析函数所展现的效果使用传统的SQL语句也能实现,但是实现方式比较复杂,效率较低。
分析函数具有三个基本的组成部分:分区子句,排序子句,开窗子句。基本语法为
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
function1
(argument1,argument2…argumentN) over([partition-by-clause]
[order-by-clause]
[windowing-clause])--说明--function1是所调用的接受0个或多个参数的分析函数--分区子句按照分区列的值对数据进行分组,所有分区列中的值相同的列放在同一个分区中--排序可以是升序也可以是降序,也可以使用nllls
first 和nulls last子句将空值放在分区的最前或者最后--开窗子句指定了分析函数运算的数据子集,具体语法如下: [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]--关键字preceding指定开窗语句的上边界,following或current
row子句指定下边界--注意分析函数不能进行嵌套。但可以通过将其包含的SQL语句放在嵌套语句中进行嵌套 |
常用函数列表

以lag函数为例
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
|
--无默认值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 2299--有默认值select 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函数不支持开窗子句,示例如下
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
select listagg(sid, ',')within group(order by sid desc)
sid from ( select sid from user where userid
= 76298 order by sid );--结果为:SID-------------------------------------31827,11199,9303,7901,5629,3254--有没有和wmsys.WM_CONCAT函数有点相似呢 |
本文介绍了Oracle数据库中的分析函数,包括其基本组成部分如分区子句、排序子句和开窗子句,并通过实例展示了如何使用LAG函数进行数据分析。此外,还特别提到了LISTAGG函数的使用限制。

被折叠的 条评论
为什么被折叠?



