如何使用逗号分隔的字符串和逗号之间的(可能的)空字段按顺序拆分字符串[重复]

问题描述 投票:0回答:1

我需要在Oracle PL / SQL中以逗号分隔顺序拆分字符串,包括空字段为“none”值。这是一个包含6个字段的示例,但可以包含更多或更少的字段

line varchar2(100) := "value1;value2;;;value5;value6;";
WITH test AS (SELECT line FROM DUAL)
  SELECT NVL(REGEXP_SUBSTR (line, '[^;]+', 1, ROWNUM),'none') as SPLIT
    FROM test
  CONNECT BY LEVEL <= LENGTH (REGEXP_REPLACE (line, '[^;]+'));

输出:

 value1      
 value2      
 value5      
 value6      
 none         
 none     

理想的输出:

value1      
value2  
none      
none  
value5      
value6      
regex oracle plsql
1个回答
3
投票
with test as (select 'value1;value2;;;value5;value6;' line from dual)
select nvl(regexp_substr (line, '([^;]*);', 1, rownum, null, 1), 'none') as split
from test
connect by level <= regexp_count (line, ';');

SPLIT                         
------------------------------
value1
value2
none
none
value5
value6

6 rows selected. 
© www.soinside.com 2019 - 2024. All rights reserved.