首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当尝试调用程序时请使用-00103

当尝试调用程序时请使用-00103
EN

Stack Overflow用户
提问于 2012-02-12 23:00:01
回答 2查看 5.1K关注 0票数 2

在试图编译时,我会得到以下错误

错误(16,8):PLS-00103:当期望下列之一时遇到符号"SPROLLUPEXPENSEITEM“::=。(@%;符号":=“改为"SPROLLUPEXPENSEITEM”以继续。

错误(17,15):请-00103:遇到符号"=“时,需要下列之一:。(*@%&+-+在<>或!=或~= >= <= <>和或类似于多集多集合的多集合成员之间的like2 like4相似c之间)是模余数而不是rem

代码语言:javascript
复制
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;

我是一个学生,在这方面非常新,所以任何帮助都将不胜感激。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-02-13 00:29:03

call不是PL/SQL中的关键字,要运行存储过程,只需使用它的名称即可。将callspRollUpExpenseItem之前删除

代码语言:javascript
复制
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;
票数 5
EN

Stack Overflow用户

发布于 2012-02-12 23:17:25

我相信你的问题在最后一次if声明中。您缺少了Then,使用的是赋值运算符:=,您应该使用=

代码语言:javascript
复制
If BlnResult = TRUE Then

或者只是

代码语言:javascript
复制
If BlnResult Then
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9253520

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档