以下有一种方法,可以让ORACLE中的表实现类似SQLSERVER中IDENTITY(1,1)序号自增的功能,原理是通过sequences与triggers触发器实现。
首先,在ORACLE建立一个sequences:
create sequence SEQ_TABLE_TEST
minvalue 1
maxvalue 999999999
start with 1
increment by 1
cache 20;
再建立一个triggers:
create or replace trigger TGR_TABLE_TEST
before insert on TABLE_TEST
for each row
declare
-- local variables here
begin
if inserting and :new.id is null then
:new.id := SEQ_TABLE_TEST.nextval;
end if;
end TGR_TABLE_TEST;
好了,这样就可以实现自增功能了,无论是正常插入:
insert into TABLE_TEST
values(seq_table_test.nextval,1.1)
还是
insert into TABLE_TEST(value)
values(1.2)
或者是
insert into TABLE_TEST(id,value)
values(null,1.3)
表TABLE_TEST中的ID字段都实现了自增的功能。
另外因为triggers中有:new.id is null的判断,当正常调用seq_table_test.nextval插入时,也不会产生浪费sequences序号的现象。
http://www.bitscn.com/pdb/oracle/201406/203096.html