Oracle主键自增

–1.使用序列实现自增
CREATE TABLE goods(
id number(10) NOT NULL PRIMARY KEY,
name varchar2(10) NULL,
weight number(10) NULL,
color varchar2(10) NULL,
TYPE varchar2(10) NULL
);

–创建序列
create sequence SEQ_Userinf
minvalue 1 --最小值
nomaxvalue --不设置最大值
start with 1 --从1开始计数
increment by 1 --每次加1个
nocycle --一直累加,不循环
nocache;

insert into goods values(SEQ_Userinf.nextval,‘苹果’,20,‘red’,‘圆’);
SELECT * FROM GOODS;

–2.触发器方式
CREATE TABLE person(
id number(10) NOT NULL PRIMARY KEY,
name varchar2(10) NULL,
weight number(10) NULL,
sex varchar2(2) NULL
);

create sequence person_seq --创建校园卡ID序列
start with 1 --序列从1开始
increment by 1 --每次增加1
minvalue 1 --最小值为1
nomaxvalue --不设最大值
nocache --没有缓存
nocycle --一直累加不循环

create or replace trigger person_trigger --创建校园卡ID触发器
before insert on person --在插入表之前
for each row --对于每一列
begin --要做的操作
select person_seq.nextval into :new.id from dual; --将下一个ID序列插入作为新的序号
end;

insert into person(name,weight,sex) values(‘tomcat’,20,‘男’);
SELECT * FROM person;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值