Oracle实现自增主键

 

Oracle实现自增主键

 

oracle没有ORACLE自增字段这样的功能,但是通过触发器(trigger)和序列(sequence)可以实现。
create table t_client (id number(4) primary key,
pid
number(4) not null,
name
varchar2(30) not null,
client_id
varchar2(10),
client_level
char(3),
bank_acct_no
varchar2(30),
contact_tel 
varchar2(30),
address   
varchar2(30),
zip_code
varchar2(10),
is_leaf
char(1) default 'y' check (is_leaf in('y','n')),
is_client
char(1) default 'n' check (is_client in('y','n')
));

假设关键字段为id,建一个序列,代码为:
create sequence seq_t_client_id
minvalue
1
maxvalue
99999999
start
with 1
increment
by 1
nocache
order;
建触发器代码为:
CREATE OR REPLACE TRIGGER trg_t_client_id
BEFORE
INSERT ON t_client
FOR EACH ROW
BEGIN
SELECT  seq_t_client_id.nextval INTO :new.id FROM dual;
END;
插入语句:

insert into allentest values(allentest_id.nextval,'helloworld2')

 

注意:创建自增主键时需要注意创建者的角色,应为相同角色进行创建;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值