首页 > 数据库技术 > 详细

关于oracle的sequence和trigger。

时间:2016-07-29 21:06:19      阅读:339      评论:0      收藏:0      [点我收藏+]

原先mysql中每个自增字段,在oracle中就需要建立一个sequence和一个trigger。

就算同一个表中有x个自增字段,那么就需要建立x个sequence和x和trigger。

 

实际中,我建立了915个sequence和915个trigger。因为mysql有915个自增自段。

生成的语句如下:

create sequence SEQ_E3_910_YUGOU_GOODSMX_ID increment by 1 start with 1
minvalue 1
nomaxvalue
nocache
order;

create trigger TRIGGER_E3_910_YUGOU_GOODSMX_I before insert on "YUGOU_GOODSMX"
for each row
begin
select SEQ_E3_910_YUGOU_GOODSMX_ID.nextval into:new."ID" from sys.dual
;
end;

有915个这样的成对语句出现。

但是运行时,报错了ORA-24344: success with compilation error。(警告: 创建的触发器带有编译错误。)

于是我只运行create sequence ,没有问题,一下跑了几百个。

再只运行create trigger ,就会报如上的错误 。

但是我把这些create trigger,在navicat里单个运行,就都能成功。

 

查了老半天,才知道原因是:http://www.2cto.com/database/201304/205599.html 

因为触发器需要先编译,每创建一个触发器,需要以“/”结束,然后才能执行下一个。

于是改为如下:

create trigger TRIGGER_E3_910_YUGOU_GOODSMX_I before insert on "YUGOU_GOODSMX"
for each row
begin
select SEQ_E3_910_YUGOU_GOODSMX_ID.nextval into:new."ID" from sys.dual
;
end;

/

就一次性跑通多个create trigger了。

 

关于oracle的sequence和trigger。

原文:http://www.cnblogs.com/stringzero/p/5719407.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!