开发者

Oracle 触发器实现主键自增效果

开发者 https://www.devze.com 2022-12-11 10:40 出处:网络 作者: 小沐哥*
触发器的作用   触发器的作用类似拦截器.把一些针对数据库的DML操作(insert/update/delete/select)进行拦截,符合编程客栈业务要求的进行操作,不符合要求的操作可以通过抛qusLy出异常来阻止

触发器的作用

  触发器的作用类似拦截器.把一些针对数据库的DML操作(insert/update/delete/select)进行拦截,符合编程客栈业务要求的进行操作,不符合要求的操作可以通过抛qusLy出异常来阻止

  说白了就是数据确认(after)与安全性检查(before),此外触发器不针对select操作

1.首先创建表testUser

Oracle设置为不区分大小的,所以table名,言简意赅即可。

CREATE TABLE testUser ( id NUMBER ( 11 ) primary key, name VARCHAR ( 50 ) );

2.创建sequence,最小值为1,最大值为99999999,初始为1,步长1

sequence名的话针对某张表习惯命名为:seq_表名

CREATE sequence seq_testUser minvalue 1 maxvalue 99999999 START WITH 1 INCREMENT BY 1 nocache ORDER;

3.创建触发器

触发器是基于sequence 所以习惯命名为:trg_sequence名

CREATE 
	OR REPLACE TRIGGER trg_seq_testUser BEFORE INSERT ON testUser FOR EACH ROW
B开发者_数据库EGIN
	SELECT
		seq_testUser.nextval INTO : new.id 
	FROM
		dual;
	
END;

4.插入一条数据

insert into testUser(username) values('强哥0编程客栈');
insert into testUser(username) values('强哥1');
insert into testUsewww.devze.comr(username) values('强哥2');

5查询结果

select * from testUser

到此这篇关于Oracle 触发器实现主键自增的文章就介绍到这了,更多相关Oracle 触发器主键自增内容请搜索我们以前的文章或继续浏览下编程客栈面的相关文章希望大家以后多多支持我们!

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号