微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

当字段内有逗号分隔时,Oracle如何对这些字段值进行分组

CREATE TABLE info(
users varchar (100)
);
INSERT INTO info VALUES ( 'userA@userB@userC' );
'userB@userC@userD' );
'userC@userD@userE' );
COLUMN "用户" FORMATA15
SELECT
to_char(strvalue) as ,
count (*) AS "用户数"
FROM
info,
table (fn_split(info.users, '@' ))
GROUP BY
to_char(strvalue)
ORDER BY
1;
-------------------------
userA1
userB2
userC3
userD2
userE1

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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
Oracle需要首先在数据库中,创建好类型与函数
来实现一个split功能的处理。
--定义一个对象类型.
CREATE OR REPLACE TYPEty_row_str_split as object(strValueVARCHAR2(4000));
/
--定义一个表/数组类型,内容是前面定义的那个对象.
TYPEty_tbl_str_split IS TABLE OF ty_row_str_split;
/
--------------------
--字符分割函数.
--参数1:被分割的源字符串
--参数2:用于拆分的字符串。
--------------------
REPLACE FUNCTION fn_split(
p_str IN VARCHAR2,
p_delimiter VARCHAR2)
RETURN ty_tbl_str_split IS
j INT :=0;
i :=1;
--被分割的源字符串的长度.
len :=0;
--分隔字符串的长度
len1 :=0;
--暂存的中间每一个单元的文本信息.
strVARCHAR2(4000);
--预期返回结果.
str_splitty_tbl_str_split:=ty_tbl_str_split();
BEGIN
--被分割的源字符串的长度.
len:=LENGTH(p_str);
--分隔字符串的长度.
len1:=LENGTH(p_delimiter);
--遍历被分割的源字符串.
WHILEj<lenLOOP
--在被分割的源字符串中,查询分隔字符串.
j:=INSTR(p_str,p_delimiter,i);
IFj=0 THEN
--j=0意味着没有找到.
--可以理解为是查询到最后一个单元了.
--设置j:=len,让外部的循环处理可以结束了.
j:=len;
--获取最后一个单元的内容.
str:=SUBSTR(p_str,i);
--结果追加一行.
str_split.EXTEND;
--设置结果内容.
str_split(str_split. COUNT ):=ty_row_str_split(strValue=>str);
IFi>=len THEN
EXIT;
END IF;
ELSE
--如果在被分割的源字符串中,找到了分隔字符串.
--首先,获取分割的内容.
sql spaces" style="font-family:Monaco,i,j-i);
--然后设置索引,下一次再查找的时候,从指定的索引位置开始(不是从0开始找了)
i:=j+len1;
--结果追加一行.
str_split.EXTEND;
--设置结果内容.
):=ty_row_str_split(strValue=>str);
IF;
LOOP;
str_split;
fn_split;
/
函数创建完毕以后,可以开始做查询的处理.
sql> select Value from (fn_split( 'aa,bb,cc' ',' ));
VALUE
-------------------------------------------------------------------------------
aa
bb
cc

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐