我本来是要把sqlserver中的数据迁移到oracle的,没想到迁移之后,程序就出错,无法插入null值,很容易就想到因为两者的id自增机制是不同的,直接迁移过来会出问题。在sqlserver中要字段自增非常简单,标识下点上自增就可以了。但是在oracle里面没有这么简单,还没有想通到底因为什么,oracle要把经常用到的自增字段分成序列(sequence)和触发器(trigger )来实现,如果有大神知道其中的细节和好处,请不吝赐教。
因为我的表是已经存在的,所有只需要上述说的两步,建立序列和触发器
1.建立序列
create sequence sq_logincrement by 1 -- 每次加几个start with 700 -- 迁移过来的,已经有记录了minvalue 1 --最小值1nomaxvalue -- 不设置最大值nocycle -- 一直累加,不循环nocache -- 不建缓冲区
2.建立触发器
create trigger tri_log before insert on dblog for each row begin select sq_log.nextval into :new.logid from dual; end tri_log;
