DECLARE是PL/SQL块的开始。一个块包括一个可选的DECLARE部分,后跟一个BEGIN部分、一个可选的EXCEPTION部分和一个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语句定义的块中的游标。这是因为PL/SQL作用域意味着不能在声明变量的块之外引用变量。
所以问题是,为什么要在嵌套块中声明这个游标?什么时候不在触发器主体的顶部声明它?