oracle 把逗号分隔符,将逗号分隔为Oracle中的列

如果您只有一行,并且有时间创建创建您自己的内置,然后你可以使用

PIVOT + LISTAGG这样做如下:select * from (

select rownum r , collection.*

from TABLE(cto_table(',','1.25, 3.87, 2, 19,, 1, 9, ')) collection)PIVOT (

LISTAGG(column_value) within group (order by 1) as val

for r in (1, 2, 3, 4, 5, 6, 7, 8, 9, 10))

FYI:下面是如何创建cto_table职能:CREATE OR REPLACE TYPE t_my_list AS TABLE OF VARCHAR2(100);CREATE OR REPLACEFUNCTION cto_table(p_sep in Varchar2, p_list IN VARCHAR2)

RETURN t_my_listAS

l_string VARCHAR2(32767) := p_list || p_sep;

l_sep_index PLS_INTEGER;

l_index PLS_INTEGER := 1;

l_tab t_my_list     := t_my_list();BEGIN

LOOP

l_sep_index := INSTR(l_string, p_sep, l_index);

EXIT

WHEN l_sep_index = 0;

l_tab.EXTEND;

l_tab(l_tab.COUNT) := TRIM(SUBSTR(l_string,l_index,l_sep_index - l_index));

l_index            := l_sep_index + 1;

END LOOP;

RETURN l_tab;END cto_table;/


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部