首页 > 代码库 > oracle利用触发器实现自增列
oracle利用触发器实现自增列
oracle利用触发器实现自增列
oracle没有自增列功能,mysql 和 sqlserver 分别用auto_increment和identity(1,1)来实现自增。oracle要实现只能通过序列实现,每次插入的时候通过取序列的值显示的给自增列,感觉有些不方便,这里使用触发器来代替,从而使插入的时候三者数据库在语法上一致,便于DAO代码的移植。下面是ORACLE实现示例,步骤如下:
1、创建表
create tabletest_user(
user_id number(10,0) primary key,
user_name varchar2(40)
);
2、创建序列
create sequencetest_user_seq start with 1 maxvalue 9999999999 increment by 1;
3、创建触发器
create or replace
triggertest_user_trigger
before insert ontest_user
for each row
begin
selecttest_user_seq.nextval into :new.user_id from dual;
end ;
4、插入数据
insert intotest_user(user_name) values(‘tom‘);
insert intotest_user(user_name) values(‘jack‘);
5、测试结果
select * from test_user;
oracle利用触发器实现自增列
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。