17,377
社区成员
发帖
与我相关
我的任务
分享
create or replace function get_roles(user_id in number ) return varchar2
is
v_name varchar2(2000);
TYPE type_cursorsss IS REF CURSOR;
cur_recwe type_cursorsss;
BEGIN
OPEN cur_recwe FOR select username from adm_user; -- 使用open for 的形式打开游标
-- 为什么不能使用这种 for in loop 的形式进行循环
-- 提示错误 ‘CUR_RECWE’ is not a procedure or is undefined
for v_name in cur_recwe loop
dbms_output.put_line(v_name);
end loop;
RETURN ''; -- 返回一个空的,故意的
end get_roles;
create or replace function get_roles(user_id in number ) return varchar2
is
v_name varchar2(2000);
TYPE type_cursorsss IS REF CURSOR;
cur_recwe type_cursorsss;
BEGIN
OPEN cur_recwe FOR select username from adm_user; -- 使用open for 的形式打开游标
-- 是不是只能使用这种 loop fetch 的形式进行循环
-- 这样没有编译报错的情况
loop
fetch cur_recwe into v_name ;
dbms_output.put_line(v_name);
end loop;
RETURN ''; -- 返回一个空的,故意的
end get_roles;
create or replace function get_roles(user_id in number ) return varchar2
is
cursor cur_rec is ( select r.name from adm_user where id = user_id) ;
-- 这样直接使用传进来的参数不行,会查询 adm_user 表中的所有记录
-- user_id 根本就没有起到作用
BEGIN
FOR cur_sin IN cur_rec LOOP
l_text := l_text || ';' || cur_sin.name;
dbms_output.put_line(l_text);
END LOOP;
RETURN ''; -- 故意返回一个空
end get_roles;
-- 使用下面的方法才有效,不知道为什么
create or replace function get_roles(user_id in number ) return varchar2
is
v_userid number := user_id; -- 先声明一个变量,并把参数赋给他
cursor cur_rec is ( select r.name from adm_user where id = v_userid) ; -- 在这儿使用 v_userid 刚才声明的变更
BEGIN
FOR cur_sin IN cur_rec LOOP
l_text := l_text || ';' || cur_sin.name;
dbms_output.put_line(l_text);
END LOOP;
RETURN ''; -- 故意返回一个空
end get_roles;
为什么不能使用这种 for in loop 的形式进行循环
--你的这个应该是可以用for的吧
create or replace function get_roles(user_id in number ) return varchar2
is
BEGIN
FOR v_name in (select username from adm_user)
loop
dbms_output.put_line(v_name);
end loop;
RETURN ''; -- 返回一个空的,故意的
end get_roles;
--游标是要先提取的 for会自动提取关闭游标 ,所以不是用for的话要先fetch的
--第一种情况你可以这么写:
create or replace function get_roles
(user_id in number )
return varchar2
is
v_name varchar2(2000);
cursor cur_recwe is
select username from adm_user;
BEGIN
for v_name in cur_recwe
loop
dbms_output.put_line(v_name);
end loop;
RETURN '';
end get_roles;