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

2 oracle plsql database-trigger

我需要在触发器中基于以下条件在BEGIN语句之后创建一个CURSOR:

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;

END IF;
Run Code Online (Sandbox Code Playgroud)

当我编译时,我收到此错误:

错误(99,5):PLS-00103:遇到以下其中一项时遇到符号"END":
begin function pragma procedure子类型
当前游标删除存在之前

如何在Oracle中触发BEGIN语句后声明游标?

APC*_*APC 5

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;
Run Code Online (Sandbox Code Playgroud)

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

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