oracle 11 自增

oracle 11,真实神一般的存在,各种bug,甚至连自增都是这么奇葩。

1.创建数据表

create table t_user(
       id int primary key,     --主键,自增长
       username varchar(20),
       password varchar(20),
       type varchar(20)
);


2. 创建序列

CREATE SEQUENCE VD_EVENTS_DATA_ID_SEQ MINVALUE 1 NOMAXVALUE INCREMENT BY 1 START WITH 1000 NOCACHE;


3.建立触发器
create OR REPLACE trigger VD_EVENTS_DATA_INS_TRG before
insert on t_user for each row when (new.id is null)
begin
 select VD_EVENTS_DATA_ID_SEQ.nextval into:new.id from dual;
end;

注意后面一行,要输入/ 否则语句无法结束。

4.添加数据

insert into t_user values(null,'aaa','aaa','admin');
insert into t_user values(null,'bbb','bbb','user');
insert into t_user values(null,'ccc','ccc','admin');
insert into t_user values(null,'ddd','ddd','user');

5. 查看结果

select * from t_user;

发布了69 篇原创文章 · 获赞 13 · 访问量 11万+

猜你喜欢

转载自blog.csdn.net/robinhunan/article/details/104011922