Oracle split函數

一、創建split函數

1、創建TYPE

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

2、創建split函數

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;
/

三、效果展示

1、使用默認分隔符


2、使用自定義分隔符


3、使用自定義多字節分隔符


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章