使用Oracle PL/SQL For循环循环遍历逗号分隔的字符串

liwlm1x9  于 2023-06-22  发布在  Oracle
关注(0)|答案(3)|浏览(334)

我正在编写一段代码,需要迭代字符串的内容,每个值都用,分隔。
我有我的elements

v_list_pak_like varchar2(4000) := 'PEBO,PTGC,PTTL,PTOP,PTA';

如何将其放入Array / Cursor中,以便在循环中对其进行迭代?

for x in (elements)
loop
   -- do my stuff
end loop;

我正在寻找非常简单的方法,如果可能的话,避免声明关联数组。

是否有可能创建一个函数,该函数将返回可用作for循环的输入(与https://stackoverflow.com/a/19184203/6019417中的while相反)?

非常感谢。

vnzz0bqm

vnzz0bqm1#

你可以在纯SQL中轻松完成。有多种方法,请参阅**Split comma delimited string into rows in Oracle**
但是,如果你真的想在PL/SQL中执行,那么你可以这样做:

SQL> set serveroutput on
SQL> DECLARE
  2    str VARCHAR2(100) := 'PEBO,PTGC,PTTL,PTOP,PTA';
  3  BEGIN
  4    FOR i IN
  5    (SELECT trim(regexp_substr(str, '[^,]+', 1, LEVEL)) l
  6    FROM dual
  7      CONNECT BY LEVEL <= regexp_count(str, ',')+1
  8    )
  9    LOOP
 10      dbms_output.put_line(i.l);
 11    END LOOP;
 12  END;
 13  /
PEBO
PTGC
PTTL
PTOP
PTA

PL/SQL procedure successfully completed.

SQL>
zaqlnxep

zaqlnxep2#

感谢Lalit的伟大指令,我能够创建一个函数,我可以从我的for循环调用:

创建类型和函数

CREATE OR REPLACE TYPE t_my_list AS TABLE OF VARCHAR2(100);
CREATE OR REPLACE
       FUNCTION comma_to_table(p_list IN VARCHAR2)
         RETURN t_my_list
       AS
         l_string VARCHAR2(32767) := p_list || ',';
         l_comma_index PLS_INTEGER;
         l_index PLS_INTEGER := 1;
         l_tab t_my_list     := t_my_list();
       BEGIN
         LOOP
           l_comma_index := INSTR(l_string, ',', l_index);
           EXIT
         WHEN l_comma_index = 0;
           l_tab.EXTEND;
           l_tab(l_tab.COUNT) := TRIM(SUBSTR(l_string,l_index,l_comma_index - l_index));
           l_index            := l_comma_index + 1;
         END LOOP;
         RETURN l_tab;
       END comma_to_table;
/

那么如何在我的 for 循环中调用:

declare
  v_list_pak_like varchar2(4000) := 'PEBO,PTGC,PTTL,PTOP,PTA';
begin
    FOR x IN (select * from (table(comma_to_table(v_list_pak_like)) ) )
    loop
        dbms_output.put_line(x.COLUMN_VALUE);
    end loop;
end;
/

注意Oracle给出的默认名称COLUMN_VALUE,这是我想要使用结果所必需的。

结果如预期:

PEBO
PTGC
PTTL
PTOP
PTA
nimxete2

nimxete23#

declare
    type array_type is table of VARCHAR2(255) NOT NULL;
    my_array array_type := array_type('aaa','bbb','ccc');
begin
    for i in my_array.first..my_array.last loop
        dbms_output.put_line( my_array(i) );
    end loop;
end;

第一行定义所需的任何类型的表。
然后声明一个该类型的变量,并用构造函数给予它的值。
然后从第一个索引到最后一个索引循环遍历结果。
Edit -处理true字符串的解决方案:

declare
    str      VARCHAR2(1024) := 'aaa,bbb,ccc';
    type     ARRAY_TYPE is table of VARCHAR2(255) NOT NULL;
    my_array ARRAY_TYPE;
begin
    SELECT REGEXP_SUBSTR(str, '[^,]+', 1, LEVEL) BULK COLLECT INTO my_array
    FROM DUAL
    CONNECT BY REGEXP_SUBSTR(str, '[^,]+', 1, LEVEL) IS NOT NULL;

    for i in my_array.first..my_array.last loop
        dbms_output.put_line( my_array(I));
    end loop;
end;

相关问题