oracle切割字串後以單列多行展示

2021-09-07 05:38:46 字數 805 閱讀 6067

原始的sql:

select substr(field1,

instr(field1, '|', 1, rownum) + 1,

instr(field1, '|', 1, rownum + 1) -

instr(field1, '|', 1, rownum) - 1) as field2

from (select '|' || 'a|bbb|cccc|ddddd|ee|d|a' || '|' as field1 from dual)

connect by instr(field1, '|', 2, rownum) > 0;

查詢結果例如以下:

field2

abbbcccc

dddddeed

a connect by :遞迴。即查詢繼續的條件

instr(field1, '|', 2, rownum)  字串從第2個位置開始。即從a開始,『|』分隔符從第一次到第八次出現的位置依次是:3、5、7、9、11、13、15、0,所以會查詢七次。也就是會有七行。

substr函式的第二個引數為instr(field1, '|', 1, rownum) + 1。表示『|』從第乙個位置開始匹配。第一到第七次匹配的位置加上一,即2、4、6、8、10、12、14

substr函式的第三個引數細緻看一下,恆等於一。

也就是說,按『|』切割後,第一次取第二部分,第二次取第四部分。依次類推。

取的值分別為:a、bbb、cccc、ddddd、ee、d、a

由於rownum是遞增的,所以會變成七行資料。

分析完成。

oracle分割字串後以單列多行展示

原始的sql select substr field1,instr field1,1,rownum 1,instr field1,1,rownum 1 instr field1,1,rownum 1 as field2 from select a bbb cccc ddddd ee d a as f...

c 切割字串

c 切割字串 1,按單一字元切割 string str org abcdce string str out str org.slipt c foreach string i in str out foreach string i in str out console.writeline i.tost...

字串二 切割

split 分割和join 合併 split 可以基於指定分隔符將字串分割成多個字串 儲存列表中 如果不指定分隔符,則預設使用空白字元 換行符 空格 製表符 join 的作用和split 作用剛好相反,用於將一系列字串聯接起率 拼接字串要點 使用字串拼接符 會生成新的字串物件,因此不推薦使用 來拼接...