Oracle SQL 劈开字符串

一、数据样例

二、劈开单行

SELECT id_,REGEXP_SUBSTR(name_, '[^,]+', 1, rownum) h2
  FROM  (select id_,name_ from test_reg_count t
  where t.id_ =2 )
CONNECT BY level <= length(name_)-length(replace(name_,',',''))+1;

--或者
SELECT id_,REGEXP_SUBSTR(name_, '[^,]+', 1, rownum) h2
  FROM  (select id_,name_ from test_reg_count t
  where t.id_ =2 )
CONNECT BY REGEXP_SUBSTR(name_, '[^,]+', 1, rownum) is not null;

三、劈开多行

SELECT id_,REGEXP_SUBSTR(name_, '[^,]+', 1, level) name_
  FROM  test_reg_count   
CONNECT BY level <= length(name_)-length(replace(name_,',',''))+1         
       AND name_ = PRIOR name_          
       AND PRIOR dbms_random.value <1;
       
--或者
SELECT id_,REGEXP_SUBSTR(name_, '[^,]+', 1, level) name_
  FROM  test_reg_count   
CONNECT BY level <= length(name_)-length(replace(name_,',',''))+1         
       AND name_ = PRIOR name_          
       AND PRIOR SYS_GUID() is not null;

这里最重要的是 prior操作符,关于prior的解释Oracle的官方文档是这么描述的:

  In a hierarchical query, one expression in the CONNECT BY condition must be qualified by the PRIOR operator. If the CONNECT BY condition is compound, then only one condition requires the PRIOR operator, although you can have multiple PRIOR conditions. PRIOR evaluates the immediately following expression for the parent row of the current row in a hierarchical query.

  PRIOR is most commonly used when comparing column values with the equality operator. (The PRIOR keyword can be on either side of the operator.) PRIOR causes Oracle to use the value of the parent row in the column. Operators other than the equal sign (=) are theoretically possible in CONNECT BY clauses. However, the conditions created by these other operators can result in an infinite loop through the possible combinations. In this case Oracle detects the loop at run time and returns an error.

转载于:https://www.cnblogs.com/Alex-Zeng/p/5920691.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值