Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/oracle/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
我可以在Oracle中触发器的BEGIN语句之后声明游标吗?_Oracle_Plsql_Database Trigger - Fatal编程技术网

我可以在Oracle中触发器的BEGIN语句之后声明游标吗?

我可以在Oracle中触发器的BEGIN语句之后声明游标吗?,oracle,plsql,database-trigger,Oracle,Plsql,Database Trigger,我需要根据如下条件在触发器中创建BEGIN语句之后的游标: 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

我需要根据如下条件在触发器中创建BEGIN语句之后的游标:

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;
编译时,会出现以下错误:

错误(99,5):PLS-00103:在预期以下情况之一时遇到符号“结束”:
开始函数pragma过程子类型类型
当前游标删除存在于之前


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

声明是PL/SQL块的开始。一个块由一个可选的DECLARE部分、一个BEGIN部分、一个可选的EXCEPTION部分和一个END部分组成

这里有一个嵌套块。Oracle希望您以一个开始和结束来遵循它。像这样:

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语句定义的块中使用游标。这是因为PL/SQL范围意味着不能在声明变量的块之外引用变量

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