gpt4 book ai didi

arrays - 如何在PL/SQL函数中使用传递数组

转载 作者:行者123 更新时间:2023-12-03 15:31:17 25 4
gpt4 key购买 nike

我是一位Java开发人员,对Oracle PL/SQL的了解有限。在下面的示例中,请让我知道如何将数组传递给PL/SQL函数以及如何调用它。

CREATE OR REPLACE FUNCTION get_employees (pUserId NUMBER)
RETURN VARCHAR2
IS
l_text VARCHAR2(32767) := NULL;
BEGIN
FOR cur_rec IN (SELECT grp.NAME GROUP_NAME FROM UserGroupRole ugr, Group_ grp WHERE ugr.groupid=grp.groupid and USERID = pUserId) LOOP
l_text := l_text || ',' || cur_rec.GROUP_NAME;
END LOOP;
RETURN LTRIM(l_text, ',');
END;
/

SELECT get_employees(414091) FROM DUAL;

最佳答案

您可以创建一个集合类型,并将参数作为该类型的实例传递。

SQL> create type num_array as table of number;
2 /

Type created.

SQL> create or replace function myfun ( arr_in num_array ) return varchar2 is
2 txt varchar2(1000);
3 begin
4 for i in 1..arr_in.count loop
5 txt := txt || to_char( arr_in(i) ) || ',';
6 end loop;
7 return txt;
8 end;
9 /

Function created.

SQL> declare
2 myarray num_array;
3 mytext varchar2(1000);
4 begin
5 myarray := num_array();
6 myarray.extend(3);
7 myarray(1) := 1;
8 myarray(2) := 5;
9 myarray(3) := 9;
10 dbms_output.put_line( myfun( myarray ));
11 end;
12 /

1,5,9,

PL/SQL procedure successfully completed.

关于arrays - 如何在PL/SQL函数中使用传递数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6338721/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com