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;