Oracle触发器实现主键自增效果,
触发器的作用
触发器的作用类似拦截器.把一些针对数据库的DML操作(insert/update/delete/select)进行拦截,符合业务要求的进行操作,不符合要求的操作可以通过抛出异常来阻止
说白了就是数据确认(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 BEGIN 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 testUser(username) values('强哥2');
5查询结果
select * from testUser
到此这篇关于Oracle 触发器实现主键自增的文章就介绍到这了,更多相关Oracle 触发器主键自增内容请搜索PHP之友以前的文章或继续浏览下面的相关文章希望大家以后多多支持PHP之友!
您可能感兴趣的文章:- Oracle创建主键自增表(sql语句实现)及触发器应用
- oracle 存储过程、函数和触发器用法实例详解
- Oracle中触发器示例详解
- Navicat Premium中Oracle创建主键自增的方法
- Springboot+MybatisPlus+Oracle实现主键自增的示例代码
本站文章为和通数据库网友分享或者投稿,欢迎任何形式的转载,但请务必注明出处.
同时文章内容如有侵犯了您的权益,请联系QQ:970679559,我们会在尽快处理。