oracle逗号分隔的字段转成多行 (oracle指定分隔符拼接行)

需求:Oracle数据库的一行里的字段需要按照逗号拆分为多行

oracle以逗号分隔字符串多行,oracle将字段分割为多行显示

实现方式:

创建自定义函数实现

1、创建类型

CREATE OR REPLACE TYPE TYPE_SPLIT IS TABLE OF VARCHAR2 (4000);

2、创建函数

CREATE OR REPLACE FUNCTION SPLIT(P_STRING VARCHAR2, P_SEP VARCHAR2 := ',')
RETURN TYPE_SPLIT
PIPELINED IS
IDX PLS_INTEGER;
V_STRING VARCHAR2(4000) := P_STRING;
BEGIN
LOOP
IDX := INSTR(V_STRING, P_SEP);
IF IDX > 0 THEN
PIPE ROW(SUBSTR(V_STRING, 1, IDX - 1));
V_STRING := SUBSTR(V_STRING, IDX + LENGTH(P_SEP));
ELSE
PIPE ROW(V_STRING);
EXIT;
END IF;
END LOOP;
END;

3、使用函数

select * FROM tmp t,table(split(t.zrrbid, ',')) t1

效果如下:

oracle以逗号分隔字符串多行,oracle将字段分割为多行显示