警告:触发与编译错误

问题描述:

我想在Oracle中创建触发器像打击创建:警告:触发与编译错误

CREATE OR REPLACE TRIGGER TRIGGER_VC_PART_LIST 
BEFORE INSERT ON VC_PART_LIST FOR EACH ROW 
BEGIN 
SELECT VC_PART_LIST_SEQ.NEWTVAL INTO :new.SEQ_ID FROM dual; 
END; 
/

任何人都可以帮我THX?

+0

使用'显示errors' –

您的代码中几乎没有问题。

1)VC_PART_LIST_SEQ.NEWTVAL在Oracle中没有什么叫做NEWTVAL。它应该是Nextval

2)不需要SQL声明。

见演示:

触发:

CREATE OR REPLACE TRIGGER TRIGGER_VC_PART_LIST 
    BEFORE INSERT 
    ON VC_PART_LIST 
    FOR EACH ROW 
BEGIN 
    :new.SEQ_ID := VC_PART_LIST_SEQ.NEXTVAL; 
END; 
/

表:

create table VC_PART_LIST (SEQ_ID number, 
VC_VTC varchar2(20), PART_NO varchar2(20), CONSUME_QTY varchar2(20)); 

序列

create sequence VC_PART_LIST_SEQ start with 1 increment by 1; 

插入:

INSERT INTO VC_PART_LIST (VC_VTC, PART_NO, CONSUME_QTY) 
    VALUES ('6175SMFGD132000D', 'SC25R136', '11'); 

Commit; 

选择:

SQL> select * from VC_PART_LIST; 

    SEQ_ID VC_VTC    PART_NO    CONSUME_QTY 
---------- -------------------- -------------------- -------------------- 
     1 6175SMFGD132000D  SC25R136    11 

按顺序取下一个值使用NEXTVAL。以下是正确的语法

CREATE OR REPLACE TRIGGER TRIGGER_VC_PART_LIST 
    BEFORE INSERT 
    ON VC_PART_LIST 
    FOR EACH ROW 
BEGIN 
    SELECT VC_PART_LIST_SEQ.NEXTVAL INTO :new.SEQ_ID FROM DUAL; 
END; 
+0

Thx.But当我inserte数据到表与另一个错误触发 'OTDTEST.TRIGGER_VC_PART_LIST'插入sql是INSERT INTO VC_PART_LIST(VC_VTC,PART_NO,CONSUME_QTY)VALUES('6175SMFGD132000D','SC25R136','11'); –

+0

分享你的表格结构。 Consume_qty是一个数字还是varchar2类型的列? – Himanshujaggi