oracle 将以逗号隔开的字符串’85,86,87′ 转成行
SELECT SUBSTR (T.RPT_ID,
INSTR (T.RPT_ID,’,’,1,C.LV)+ 1,
INSTR (T.RPT_ID,’,’,1,C.LV + 1)- (INSTR (T.RPT_ID,’,’,1,C.LV)+ 1))
AS RPT_ID
FROM (SELECT ‘,’ || ‘85,86,87’ || ‘,’ RPT_ID,
LENGTH (‘85,86,87’ || ‘,’) – NVL (LENGTH (REPLACE (‘85,86’, ‘,’)), 0) CNT
FROM DUAL) t,
(SELECT LEVEL lv
FROM DUAL
CONNECT BY LEVEL WHERE T.cnt >= c.lv
说明:CNT表示串里面有多少字符。
当是字符串是表中的字段时,取level如:
1).取最大个数
SELECT MAX(LENGTH(RPT_ID || ‘,’) –
NVL(LENGTH(REPLACE(RPT_ID, ‘,’)), 0)) INTO v_c
FROM DIM_AUDIT_TABLE@sjmh_inter;
2).l转成行
SELECT T.T_NAME,
T.T_NAME_COMM,
T.T_COLUMN,
T.T_COLUMN_COMM,
t.COMMENT_NL,
t.COMMENT_NL_TIME,
t.SEQ_USER_ID,
SUBSTR(T.RPT_ID,
INSTR(T.RPT_ID, ”,”, 1, C.LV) + 1,
INSTR(T.RPT_ID, ”,”, 1, C.LV + 1) –
(INSTR(T.RPT_ID, ”,”, 1, C.LV) + 1)) AS RPT_ID
FROM (SELECT A.T_NAME,
A.T_NAME_COMM,
A.T_COLUMN,
A.T_COLUMN_COMM,
a.COMMENT_NL,
a.COMMENT_NL_TIME,
a.SEQ_USER_ID,
”,” || A.RPT_ID || ”,” RPT_ID,
LENGTH(A.RPT_ID || ”,”) –
NVL(LENGTH(REPLACE(A.RPT_ID, ”,”)), 0) CNT
FROM DIM_AUDIT_TABLE@sjmh_inter A
WHERE a.COMMENT_NL is not null) T,
(SELECT LEVEL LV FROM DUAL CONNECT BY LEVEL WHERE C.LV
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/434648.html
微信扫一扫
支付宝扫一扫