码迷,mamicode.com
首页 > 数据库 > 详细

oracle 实现主键自增

时间:2018-07-13 21:30:14      阅读:172      评论:0      收藏:0      [点我收藏+]

标签:number   sequence   创建表   oca   --   row   rem   create   art   

-- 创建表

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;

oracle 实现主键自增

标签:number   sequence   创建表   oca   --   row   rem   create   art   

原文地址:https://www.cnblogs.com/BaiLaowu/p/9307395.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!