Oracle SQL 劈开字符串

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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.

以上是关于Oracle SQL 劈开字符串的主要内容,如果未能解决你的问题,请参考以下文章

sql数据库截取字符串函数

如何在 Toad for Oracle 中使用自定义代码片段?

text 劈开盒子

我可以使用Java代码在sql语句(Oracle)的IN子句中传递字符串列表吗

获取url指定的查询字符串

654. Maximum Binary Tree 最大节点劈开,然后左边右边排序