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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了oracle中的存储过程如何返回查询到的多个值?相关的知识,希望对你有一定的参考价值。

感觉oracle数据库中的存储过程和函数的使用没有ms sql中的的存储过程和函数容易使用!

oracle不是不能,而是采用的方法不同罢了。
可以使用一下方法创建返回结果集的调用:
SQL> create or replace package pkg_HelloWorld as
2 -- 定义ref cursor类型
3 type myrctype is ref cursor;
4 --函数申明
5 function getHelloWorld return myrctype;
6 end pkg_HelloWorld;

Package created.

SQL> CREATE OR REPLACE package body pkg_HelloWorld as
2 function getHelloWorld return myrctype
3 IS
4 return_cursor myrctype;
5 BEGIN
6 OPEN return_cursor FOR 'SELECT ''Hello'' AS a, ''World'' AS B FROM dual';
7 return return_cursor;
8 END getHelloWorld;
9 end pkg_HelloWorld;

Package body created.

SQL> SELECT pkg_HelloWorld.getHelloWorld FROM dual;
GETHELLOWORLD
--------------------
CURSOR STATEMENT : 1
CURSOR STATEMENT : 1
A B
---------- ----------
Hello World
参考技术A SQL Server的存储过程,可以在里面写一段SQL语句,然后其它的开发语言比如C#,可以在调用存储过程的后,获取到存储过程执行所返回的结果集。

此方法在 SQL Server 中可用,在 Oracle 中不可用。

首先举一个 SQL Server 的成功的例子:

CREATEPROCEDURE testProc
AS
BEGIN
SELECT'Hello 1'AS A,'World 1'AS B UNIONALL
SELECT'Hello 2'AS A,'World 2'AS B;
END

BEGIN
DECLARE @RC int;
EXECUTE @RC = testProc;
PRINT @RC;
END

A B
------- -------
Hello 1 World 1
Hello 2 World 2
(2 行受影响)
0

然后 照着写一个 Oracle 的。
SQL> CREATE OR REPLACE PROCEDURE testProc
2 AS
3 BEGIN
4 SELECT 'Hello 1' AS A, 'World 1' AS B FROM DUAL UNION ALL
5 SELECT 'Hello 2' AS A, 'World 2' AS B FROM DUAL ;
6 END;
7 /
警告:创建的过程带有编译错误。

SQL> show err;
PROCEDURE TESTPROC出现错误:
LINE/COL ERROR
-------- -----------------------------------------------------------------
4/3 PLS-00428: 在此 SELECT 语句中缺少 INTO 子句

假如要实现 存储过程返回结果集,以便让 C# 之类的代码调用的话,请参考 Oracle 函数 当中的 返回结果集的函数的部分。

参考资料:http://hi.baidu.com/wangzhiqing999/blog/item/0991d3124070854420a4e9b4.html

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中的存储过程如何返回查询到的多个值?的主要内容,如果未能解决你的问题,请参考以下文章

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

如何从 Oracle 存储过程中获取两个返回值

C# 存储过程 如何返回 tatatable

oracle如何执行存储过程以及如何返回一个table

带有可能缺少某些搜索条件的查询的 Oracle 存储过程

如何从 Access 2010 中的 SQL 存储过程返回多个记录集