oracle如何执行存储过程以及如何返回一个table
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle如何执行存储过程以及如何返回一个table相关的知识,希望对你有一定的参考价值。
之前从来没有用oracle,想问下如何执行oracle的存储过程,之前按照sqlserver的执行方式发现不对。
exec 存储过程名 参数名
这样不对吗?
没有用sqlpuls,使用的青蛙Toad,里面那样执行不对。。
再问下oracle的sp不能返回一个table似的查询结果吗?
只能是一个结果一个结果的返回吗?
只知道好像可以使用游标来是SP返回一个table?
这个要怎样去写?
CREATE OR REPLACE TYPE MyTable AS OBJECT(A int, B int, C int);
/
CREATE OR REPLACE TYPE MyTableResult IS TABLE OF MyTable;
/
CREATE OR REPLACE FUNCTION getTestTable return MyTableResult
IS
-- 预期返回结果.
return_Result MyTableResult := MyTableResult();
BEGIN
-- 结果追加一行.
return_Result.EXTEND;
-- 设置结果内容.
return_Result(return_Result.COUNT) := MyTable(A => 1, B=>2, C=>3);
-- 结果追加一行.
return_Result.EXTEND;
-- 设置结果内容.
return_Result(return_Result.COUNT) := MyTable(A => 4, B=>5, C=>6);
-- 结果追加一行.
return_Result.EXTEND;
-- 设置结果内容.
return_Result(return_Result.COUNT) := MyTable(A => 7, B=>8, C=>9);
return return_Result;
END getTestTable;
/
SQL> SELECT
2 A, B, C
3 FROM
4 table( getTestTable() );
A B C
---------- ---------- ----------
1 2 3
4 5 6
7 8 9
SQL> 参考技术A 过程的执行如下:
begin
sp;
end;
返回一个table使用自定义函数来处理好一些追问
青蛙里这样执行?不行的
参考技术B 执行一个带有输出参数的动态游标的存储过程即可1.在包头要定义一个全局的动态游标
Type REF游标名 IS Ref Cursor;
2.定义一个输出参数为上述游标类型的存储过程
create or replace sp_test(o_list out REF游标名)
..
begin
--打开游标
open o_list..
end
3.执行上述存储过程
declare
REF_CUR 上述动态游标所属包名.REF游标名;
begin
-- Call the procedure
上述存储过程所属包名.sp_test(REF_CUR);
--游标数据处理..
end;
没有环境,大体上是这个流程本回答被提问者采纳
以上是关于oracle如何执行存储过程以及如何返回一个table的主要内容,如果未能解决你的问题,请参考以下文章
如何创建可以返回特定实体以及所有实体的 Oracle 存储过程