警告:触发与编译错误
我想在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?
您的代码中几乎没有问题。
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;
Thx.But当我inserte数据到表与另一个错误触发 'OTDTEST.TRIGGER_VC_PART_LIST'插入sql是INSERT INTO VC_PART_LIST(VC_VTC,PART_NO,CONSUME_QTY)VALUES('6175SMFGD132000D','SC25R136','11'); –
分享你的表格结构。 Consume_qty是一个数字还是varchar2类型的列? – Himanshujaggi
使用'显示errors' –