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 存储过程

如何使用c#执行返回多个游标的oracle存储过程

java中如何获取oracle存储过程返回的多个值。

oracle中的存储过程如何返回查询到的多个值?

请问MyBatis.net 如何执行一个不需要参数但返回结果集的oracle数据库的存储过程?

Oracle 数据量非常大(上亿)时,使用存储过程中的游标返回分页查询的10条记录非常耗时,请问如何优化?