oracle存储过程如何返回一个结果集,一定要用ref cursor吗?存储过程在pl/sql中是怎么调用的,越详细越好 5

 我来答
春光照宇寰3
2013-01-28 · TA获得超过1013个赞
知道小有建树答主
回答量:649
采纳率:100%
帮助的人:449万
展开全部
知道包这个概念么?
---创建包头

CREATE OR REPLACE PACKAGE PKG_User IS

TYPE T_CURSOR IS REF CURSOR;
PROCEDURE GET(p_user_id in varchar2,cur_out OUT T_CURSOR);
END PKG_User;
--创建包体

CREATE OR REPLACE PACKAGE BODY PKG_User IS
----Get by KeyId----------
PROCEDURE GET(p_user_id in varchar2,cur_out OUT T_CURSOR) IS
BEGIN
OPEN cur_out FOR
select user_id,
user_pid,
uname,
status,
nvl(company_id,-1) company_id,
nvl(dept_id,-1) dept_id,
nvl(station_id,-1) station_id,
nvl(subsys,-1) subsys,
nvl(user_type,-1) user_type,
keys
from TB_USER
where upper(user_id)=upper(p_user_id);
END ;
end PKG_User;
调用使用PKG_User.GET
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
请叫我召哥
2013-01-17 · TA获得超过792个赞
知道小有建树答主
回答量:572
采纳率:95%
帮助的人:375万
展开全部
CREATE OR REPLACE TYPE Varchar2Varray IS VARRAY(100) of VARCHAR2(40);
/
CREATE OR REPLACE FUNCTION sf_split_string (string VARCHAR2, substring VARCHAR2) RETURN Varchar2Varray IS
len integer := LENGTH(substring);
lastpos integer := 1 - len;
pos integer;
num integer;
i integer := 1;
ret Varchar2Varray := Varchar2Varray(NULL);
BEGIN
LOOP
pos := instr(string, substring, lastpos + len);
IF pos > 0 THEN --found
num := pos - (lastpos + len);
ELSE --not found
num := LENGTH(string) + 1 - (lastpos + len);
END IF;
IF i > ret.LAST THEN
ret.EXTEND;
END IF;
ret(i) := SUBSTR(string, lastpos + len, num);
EXIT WHEN pos = 0;
lastpos := pos;
i := i + 1;
END LOOP;
RETURN ret;
END;
/

测试:
SQL> select * from table (cast (
sf_split_string('ABC,DEFGH,IJKLMN,OPQRST', ',') as Varchar2Varray) );
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
fmilove
2013-01-17 · TA获得超过155个赞
知道小有建树答主
回答量:442
采纳率:0%
帮助的人:127万
展开全部
execute 过程
来自:求助得到的回答
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
tim_spac
2013-01-17 · TA获得超过3628个赞
知道大有可为答主
回答量:1804
采纳率:100%
帮助的人:2005万
展开全部
--1.存储过程
create or replace procedure print(msg varchar2)
is
begin
dbms_output.put_line(msg);
end;

--1.1 调用存储过程
execute print('helloworld');
追问
应该是数据集,返回值类似于sql server中的select * from table_name,如果在oracle存储过程里面这样写的话就会报错
追答
"dbms_output" 是oracle存储过程的输出容器,
"cursor" 是常用的查询结果集合遍历方法;

不定义游标在存储过程中使用查询结果的另一中方法示例:

FOR rec IN (SELECT table_name FROM user_tables)
LOOP
dbms_output.put_line (rec.table_name);
END LOOP;

参考资料: http://zhidao.baidu.com/question/74047685.html

来自:求助得到的回答
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式