Oracle中SYS_CONNECT_BY_PATH函数的妙用 ;

时间:2023-03-08 23:14:10
Oracle中SYS_CONNECT_BY_PATH函数的妙用 ;

Oracle 中SYS_CONNECT_BY_PATH函数是非常重要的函数,下面就为您介绍一个使用SYS_CONNECT_BY_PATH函数的例子,实例如下:

数据准备:

 create table test (a varchar2(10),b varchar2(10));  

 INSERT INTO TEST (A, B) VALUES ('', 'A');
INSERT INTO TEST (A, B) VALUES ('', 'B');
INSERT INTO TEST (A, B) VALUES ('', 'X');
INSERT INTO TEST (A, B) VALUES ('', 'Y'); SELECT A, B FROM TEST ;

Oracle中SYS_CONNECT_BY_PATH函数的妙用 ;

 SELECT A, LTRIM(MAX(SYS_CONNECT_BY_PATH(B, ' ')), ',') B
FROM (SELECT B, A, ROW_NUMBER() OVER(PARTITION BY A ORDER BY B DESC) RN
FROM TEST)
START WITH RN = 1
CONNECT BY RN - 1 = PRIOR RN
AND A = PRIOR A
GROUP BY A;

Oracle中SYS_CONNECT_BY_PATH函数的妙用 ;

------------------------------------------

将 'A,B,C,D,E,F,G'拆分成行显示 ;

 /*
1.分析先找出有多少个‘,’逗号:length(str) - length(regexp_replace(str, ',', '')) + 1 ;
2.再根据regexp_substr()函数进行查找逗号的位置 ;
regexp_substr(str, '[^,]+', 1, level, 'i') as str ,这里的level代表第几个逗号(‘,’) 3.function REGEXP_SUBSTR(__srcstr, __pattern, __position, __occurrence, __modifier) ;
参数的含义:
__srcstr :需要进行正则处理的字符串
__pattern :进行匹配的正则表达式
__position :起始位置,从第几个字符开始正则表达式匹配(默认为1)
__occurrence :标识第几个匹配组,默认为1
__modifier :模式('i'不区分大小写进行检索;'c'区分大小写进行检索。默认为'c'。)
*/ with temp as
(select 'A,B,C,D,E,F,G' str from dual)
select regexp_substr(str, '[^,]+', 1, level, 'i') as str
from temp
connect by level <= length(str) - length(regexp_replace(str, ',', '')) + 1;
1 A,B,C,D,E,F,G' 
 
1 A
1 B
1 C
1 D
1 E
1 F