oracle自增字段设置

以前在使用mysql 和SQL server时,他们都有自增字段设置的关键字,在创建表时一并创建。现在使用oracle发现没有自增字段这样的功能,可以通过触发器trigger和序列sequence来实现:
先建一个测试表:
create table scott.TableName



id   number(6) not null, 
name   varchar2(30)   not null primary key


)
第一步:创建SEQUENCE
create sequence SeqName 
increment by 1 
start with 1 
minvalue 1 
maxvalue 9999999999999 
nocache order;
第二步:创建一个基于该表的before insert 触发器,在触发器中使用刚创建的SEQUENCE
create or replace trigger TriggerName 
before insert on scott.TableName
for each row 
begin 
      select  SeqName.nextval   into:new.id from sys.dual ; 
end; 
第三步:在TableName表中测试
insert into scott.TableName (name) values ('wang');
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值