首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Oracle触发器create with compilation错误

Oracle触发器create with compilation错误
EN

Stack Overflow用户
提问于 2013-02-26 23:29:23
回答 1查看 6.6K关注 0票数 1

我编写了下面的触发器,以防止用户在Class Date与会话所在的星期几不匹配时将Class分配给会话。

代码语言:javascript
复制
CREATE OR REPLACE TRIGGER trig_alternative_classDate
AFTER INSERT OR UPDATE ON ALTERNATIVE
FOR EACH ROW
DECLARE
    classdate CHAR;
    sessionday VARCHAR;
BEGIN
    SELECT to_char(to_date(class.class_date), 'Day') INTO classdate, sessions.day INTO sessionday
    FROM SESSIONS, CLASS, DUAL, LOCATION, ALTERNATIVE
    WHERE class.class_id = alternative.class_id
    AND alternative.location_id = location.location_id
    AND sessions.location_id = location.location_id;
    IF sessions.day != to_char(to_date(class.class_date), 'Day')
    THEN raise_application_error(-20999,'Invalid Class Date - Class Date does not match Session Day');
    END IF;
END;
/

但是,我在运行触发器时收到一条错误消息

代码语言:javascript
复制
Warning: Trigger created with compilation errors.

SQL> show error trigger trig_alternative_classDate
Errors for TRIGGER TRIG_ALTERNATIVE_CLASSDATE:

LINE/COL ERROR
-------- -----------------------------------------------------------------
5/2  PL/SQL: SQL Statement ignored
5/80 PL/SQL: ORA-00923: FROM keyword not found where expected

有没有人能帮帮忙?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-02-26 23:37:01

删除第二个INTO -只需要一个INTO:

代码语言:javascript
复制
INTO classdate, sessions.day INTO sessionday
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15092940

复制
相关文章

相似问题

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