如果您不想更新现有表,而只想选择数据,则可以使用这种费力的查询.
WITH changed_table AS
(SELECT val1, EXTRACTVALUE (x.COLUMN_VALUE, 'e') val2new
FROM (SELECT val1, val2 xml_str
FROM table1),
TABLE (XMLSEQUENCE (XMLTYPE ( ''
|| REPLACE (xml_str, ',', '')
|| ''
).EXTRACT ('e/e')
)
) x)
SELECT ct.val1, listagg(table2.val2,',') within group (order by table2.val2) val2
FROM changed_table ct, table2 table2
WHERE ct.val2new = table2.val1
group by ct.val1;
我已经使用XMLTYPE将逗号分隔的数字分隔为行.然后将行与第二个表连接起来以获得描述,最后使用LISTAGG函数形成逗号分隔的字符串.不知道此查询的效率如何.我同意马克·班尼斯特的评论.