Sql 将两个相互依赖的字符串拆分为行

Sql 将两个相互依赖的字符串拆分为行,sql,string,oracle,split,xmltable,Sql,String,Oracle,Split,Xmltable,我有两个逗号分隔的字符串,如下所示: 'number1,number2,number3' 'word1, word2, word3' 我想把它们分成几行,保持值的顺序。预期结果是: COL1               COL2 ------------------------- number1          word1 number2          word2 number3          word3 有一个特殊的条件:我们不能使用方括号符号-[…] 另外,我发现了如何使用XM

我有两个逗号分隔的字符串,如下所示:

'number1,number2,number3'
'word1, word2, word3'
我想把它们分成几行,保持值的顺序。预期结果是:

COL1               COL2
-------------------------
number1          word1
number2          word2
number3          word3
有一个特殊的条件:我们不能使用方括号符号-[…]


另外,我发现了如何使用XMLTable拆分单个字符串,但我不知道如何将其与保持相同顺序的第二个字符串的值连接起来。

我认为您不需要担心顺序,因为行是固定的,并且字符串的substr值顺序相同

Update OP希望坚持使用XMLTABLE解决方案

使用XMLTABLE

使用REGEXP\u SUBSTR


有关更多示例,请参见Hi@Lalit!感谢您的回答,但在我的情况下禁止使用方括号。您在我的博客中找到的xmltable解决方案将正常工作。你只需要加入他们。就像你把两张桌子连在一起一样。
SQL> WITH input_data AS
  2    (SELECT 'number1,number2,number3' str1, 'word1, word2, word3' str2 FROM dual
  3    ) ,
  4    temp_data1 AS
  5    (SELECT rownum rn,
  6      trim(COLUMN_VALUE) str1
  7    FROM input_data,
  8      xmltable(('"'
  9      || REPLACE(str1, ',', '","')
 10      || '"'))
 11    ) ,
 12    temp_data2 AS
 13    (SELECT rownum rn,
 14      trim(COLUMN_VALUE) str2
 15    FROM input_data,
 16      xmltable(('"'
 17      || REPLACE(str2, ',', '","')
 18      || '"'))
 19    )
 20  SELECT t1.str1,
 21    t2.str2
 22  FROM temp_data1 t1,
 23    temp_data2 t2
 24  WHERE t1.rn = t2.rn
 25  /

STR1    STR2
------- -------
number1 word1
number2 word2
number3 word3

SQL>
SQL> WITH DATA AS
  2    ( SELECT 'number1,number2,number3' str1, 'word1, word2, word3' str2 FROM dual
  3    )
  4  SELECT trim(regexp_substr(str1, '[^,]+', 1, LEVEL)) str1,
  5    trim(regexp_substr(str2, '[^,]+', 1, LEVEL)) str2
  6  FROM DATA
  7    CONNECT BY LEVEL <= regexp_count(str1, ',')+1
  8  /

STR1                    STR2
----------------------- -------------------
number1                 word1
number2                 word2
number3                 word3

SQL>