在oracle下 cursor,我可以在Oracle的BEGIN触发语句之后声明一个CURSOR吗?

DECLARE是PL / SQL块的开始 . 一个块包含一个可选的DECLARE部分,后跟一个BEGIN部分,一个可选的EXCEPTION部分,最后一个END .

你在这里有一个嵌套块 . Oracle希望您使用BEGIN和END跟随它 . 像这样:

IF :OLD.DWF_STATUS = 'P' AND :NEW.DWF_STATUS = 'C' THEN

DECLARE CURSOR cur_list IS

SELECT DISTINCT DR_PRJ_ID, STR_EMAIL, DWFU_US_ID

FROM DOC_WORKFLOW JOIN DOC_WF_USERS ON DWFU_DWF_ID = DWF_ID

JOIN DOCUMENT_REF ON DWF_DR_ID = DR_ID AND DR_TYPE = 'P'

LEFT OUTER JOIN ST_REGISTER ON STR_ID = DWFU_STR_ID

WHERE DWF_ID = :NEW.DWF_ID;

begin

-- some code here

end;

END IF;

也就是说,您必须编写代码以在DECLARE语句定义的块中使用Cursor . 这是因为PL / SQL范围意味着变量不能在声明它们的块之外引用 .

所以问题是,为什么要在嵌套块中声明这个游标?什么时候不只是在触发器体的顶部声明它?

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值