加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

oracle单字段拆分成多行

发布时间:2020-12-12 13:17:28 所属栏目:百科 来源:网络整理
导读:已上图为例 先以逗号分隔拆分 拆分函数: CREATE OR REPLACE FUNCTION SPLIT(P_STRING VARCHAR2,P_SEP VARCHAR2 := ‘,‘)RETURN TYPE_SPLITPIPELINED ISIDX PLS_INTEGER;V_STRING VARCHAR2(4000) := P_STRING;BEGINLOOPIDX := INSTR(V_STRING,P_SEP);IF IDX

已上图为例

先以逗号分隔拆分

拆分函数:

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;

  下面是sql语言:

select * from(select d.news_id,d.hot_tag_name from news_data d where d.news_id=101166699) t,table(split(t.hot_tag_name,‘,‘)) t1

  执行效果:

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读