oracle 主键自增函数_oracle 实现主键自增

该篇博客介绍了如何在Oracle数据库中创建和删除表,以及如何定义序列和触发器。详细步骤包括创建名为test的表,定义seq_id序列,并为test表创建一个在插入时自动填充id的触发器。此外,还展示了插入数据和查询表内容的操作。
摘要由CSDN通过智能技术生成

-- 创建表

drop table test;

create table test(id number(10), name varchar2(10));

-- 创建对列

drop sequence seq_id;

create sequence seq_id minvalue 1 nomaxvalue start with 1 increment by 1 nocycle nocache;

/*

minvalue 1     最小值

nomaxvalue     不设置最大值(由机器决定),或根据表字段的值范围设置 maxvalue

start with 1   从1开始计数,数值可变

increment by 1 每次加1,数值可变

nocycle        一直累加,不循环

nocache        不建缓冲区,如果建立cache那么系统将自动读取cache值个seq,这样会加快运行速度;

如果当机或oracle死了,那么下次读取的seq值将不连贯*/

-- sys 登陆授权

grant create trigger to scott;

-- 创建触发器, 注意创建触发器 “end;” 后面必须加一个回车和“/”,才可以执行;

create or replace trigger test_id_increment

before insert on test

for each row

begin

select seq_id.nextval into:new.id from dual;

end;

/

-- 测试

select * from test;

insert into test(name) values('张三');

insert into test values(null, '张三');

select * from test;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值