在试图编译时,我会得到以下错误
错误(16,8):PLS-00103:当期望下列之一时遇到符号"SPROLLUPEXPENSEITEM“::=。(@%;符号":=“改为"SPROLLUPEXPENSEITEM”以继续。
和
错误(17,15):请-00103:遇到符号"=“时,需要下列之一:。(*@%&+-+在<>或!=或~= >= <= <>和或类似于多集多集合的多集合成员之间的like2 like4相似c之间)是模余数而不是rem
create or replace
TRIGGER tr_ExpenseItem_Rollup
AFTER DELETE OR UPDATE of ExpApprAmt
ON ExpenseItem
FOR EACH ROW
DECLARE
RollupAmt Number;
BlnResult Boolean;
BEGIN
IF DELETING THEN
RollupAmt := -1 * :Old.ExpApprAmt;
End If;
IF UPDATING Then
RollupAmt := :New.ExpApprAmt - :Old.ExpApprAmt;
End IF;
Call spRollUpExpenseItem(:New.ERNo,:New.ECNo,RollupAmt,BlnResult);
If BlnResult := TRUE
--Additional Logic Here
End IF;
END;我是一个学生,在这方面非常新,所以任何帮助都将不胜感激。
发布于 2012-02-13 00:29:03
call不是PL/SQL中的关键字,要运行存储过程,只需使用它的名称即可。将call从spRollUpExpenseItem之前删除
create or replace
TRIGGER tr_ExpenseItem_Rollup
AFTER DELETE OR UPDATE of ExpApprAmt
ON ExpenseItem
FOR EACH ROW
DECLARE
RollupAmt Number;
BlnResult Boolean;
BEGIN
IF DELETING THEN
RollupAmt := -1 * :Old.ExpApprAmt;
End If;
IF UPDATING Then
RollupAmt := :New.ExpApprAmt - :Old.ExpApprAmt;
End IF;
spRollUpExpenseItem(:New.ERNo,:New.ECNo,RollupAmt,BlnResult);
If BlnResult = TRUE Then
--Additional Logic Here
End IF;
END;发布于 2012-02-12 23:17:25
我相信你的问题在最后一次if声明中。您缺少了Then,使用的是赋值运算符:=,您应该使用=。
If BlnResult = TRUE Then或者只是
If BlnResult Thenhttps://stackoverflow.com/questions/9253520
复制相似问题