Oracle数据库字段拆分

Oracle数据库字段拆分,第1张

SELECT REGEXP_SUBSTR(t.PATH_IDS||',', '[^,]+', 1, 1),

       REGEXP_SUBSTR(t.PATH_IDS||',', '[^,]+', 1, 2),

       REGEXP_SUBSTR(t.PATH_IDS||',', '[^,]+', 1, 3),

       DECODE(REGEXP_SUBSTR(t.PATH_IDS||',', '[^,]+', 1, 5), NULL, NULL, REGEXP_SUBSTR(t.PATH_IDS||',', '[^,]+', 1, 4)),

       DECODE(REGEXP_SUBSTR(t.PATH_IDS||',', '[^,]+', 1, 5), NULL, REGEXP_SUBSTR(t.PATH_IDS||',', '[^,]+', 1, 4), REGEXP_SUBSTR(t.PATH_IDS||',', '[^,]+', 1, 5))

FROM 机构层级关系表 t

前三列根据正则匹配,获取对应的分割后的值,没有啥讲的,

第四列要判断是否存在第五列,如果不存在,则第四列要空,存在则用第四列的值

第五列要判断是否存在第五列,如果不存在,则给第四列的值,存在则用第五列的值

认真分解一下呗,这么简单:

1==>:这个是第一行开始的标记。

<+_+>:这个是记录与记录之间的分割符号。

<@_@>:这个是字段与字段之间的分割符号。

然后如果是在C#里分分割就编程呗。

如果想要在数据库里面分割,就写一个存储过程呗。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9982904.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-04
下一篇 2023-05-04

发表评论

登录后才能评论

评论列表(0条)

保存