oracle 动态sql like,如何从执行动态SQL的Oracle PL/SQL匿名块返回结果集/游标?

我有这个表:

ALLITEMS

---------------

ItemId | Areas

---------------

1 | EAST

2 | EAST

3 | SOUTH

4 | WEST

DDL:

drop table allitems;

Create Table Allitems(ItemId Int,areas Varchar2(20));

Insert Into Allitems(Itemid,Areas) Values(1,'east');

Insert Into Allitems(ItemId,areas) Values(2,'east');

insert into allitems(ItemId,areas) values(3,'south');

insert into allitems(ItemId,areas) values(4,'east');

在MSSQL中,要从动态SQL获取游标,我可以做:

DECLARE @v_sqlStatement VARCHAR(2000);

SET @v_Sqlstatement = 'SELECT * FROM ALLITEMS';

EXEC (@v_sqlStatement); --returns a resultset/cursor, just like calling SELECT

在Oracle中,我需要使用PL / SQL块:

SET AUTOPRINT ON;

DECLARE

V_Sqlstatement Varchar2(2000);

outputData SYS_REFCURSOR;

BEGIN

V_Sqlstatement := 'SELECT * FROM ALLITEMS';

OPEN outputData for v_Sqlstatement;

End;

--result is : anonymous block completed

但我所得到的只是“匿名块完成”。

如何让它返回光标?

(我知道如果我做AUTOPRINT,它将打印出REFCURSOR中的信息(它不是在上面的代码中打印,而是另一个问题))

我将从代码(ODBC,C)中调用此动态SQL,我需要它返回一个游标。

我该如何做?我被困了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值