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

感觉oracle数据库中的存储过程和函数的使用没有mssql中的的存储过程和函数容易使用!... 感觉oracle数据库中的存储过程和函数的使用没有ms sql中的的存储过程和函数容易使用! 展开
 我来答
百度网友acd2bef
2011-10-14 · TA获得超过1438个赞
知道小有建树答主
回答量:920
采纳率:100%
帮助的人:776万
展开全部
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
wangzhiqing999
2011-10-07 · TA获得超过1.6万个赞
知道大有可为答主
回答量:7048
采纳率:100%
帮助的人:3354万
展开全部
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

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式