Oracle 自定義split 函數(shù)實例詳解
更新時間:2017年01月05日 11:30:24 投稿:lqh
這篇文章主要介紹了Oracle 自定義split 函數(shù)實例詳解的相關資料,需要的朋友可以參考下
Oracle 自定義split 函數(shù)
Oracle沒有提供split函數(shù),但可以自己建立一個函數(shù)實現(xiàn)此功能。比如“abc defg hijkl nmopqr stuvw xyz”,分隔符是空格,但空格個數(shù)不定。
源代碼:
CREATE OR REPLACE TYPE ty_str_split IS TABLE OF VARCHAR2 (4000); CREATE OR REPLACE FUNCTION fn_var_split ( p_str IN VARCHAR2, p_delimiter IN VARCHAR2 ) RETURN ty_str_split IS j INT := 0; len INT := 0; str VARCHAR2 (4000); str_split ty_str_split := ty_str_split (); v_str VARCHAR2 (4000) := RTRIM (LTRIM (p_str, p_delimiter), p_delimiter); BEGIN len := LENGTH (v_str); WHILE len > 0 LOOP j := INSTR (v_str, p_delimiter, 1); IF j = 0 THEN str := SUBSTR (v_str, 1); len := 0; str_split.EXTEND; str_split (str_split.COUNT) := str; ELSE str := SUBSTR (v_str, 1, j - 1); v_str := LTRIM (LTRIM (v_str, str), p_delimiter); len := LENGTH (v_str); str_split.EXTEND; str_split (str_split.COUNT) := str; END IF; END LOOP; RETURN str_split; END fn_var_split; /
測試:
結(jié)果:
1 12 123 1234 12345
DECLARE CURSOR c IS SELECT * FROM TABLE (CAST (fn_var_split (';1;12;;123;;;1234;;;;12345;', ';') AS ty_str_split)); r c%ROWTYPE; BEGIN OPEN c; LOOP FETCH c INTO r; EXIT WHEN c%NOTFOUND; DBMS_OUTPUT.put_line (r.column_value); END LOOP; CLOSE c; END; /
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關文章
oracle誤drop/update操作后的數(shù)據(jù)恢復測試
本人主要是對drop/update數(shù)據(jù)后,在允許有時間內(nèi)進行數(shù)據(jù)恢復,操作性強,比較實用。不對理論進行講訴,需要的朋友可以參考下2015-08-08整理Oracle數(shù)據(jù)庫中數(shù)據(jù)查詢優(yōu)化的一些關鍵點
這篇文章主要介紹了Oracle數(shù)據(jù)庫中數(shù)據(jù)查詢優(yōu)化的一些關鍵點的整理,包括多表和大表查詢等情況的四個方面的講解,需要的朋友可以參考下2016-01-01