如果想在Oracle数据库里实现数据表主键自增,我们似乎没有办法像MySql般直接定义列的属性来实现。不过对于这个数据库的常用功能,我们还是有办法实现的。这里将展示使用触发器来实现主键自增。
1.准备
创建UserInfo表,结构如下:
CREATE TABLE UserInfo
(
id NUMBER(10) NOT NULL,
username VARCHAR2(15) NOT NULL,
password VARCHAR2(15) NOT NULL,
CONSTRAINTS PF_UserInfo PRIMARY KEY(id) --创建主键约束
);

创建一个用于自增的序列(requence)
CREATE SEQUENCE Tab_UserInfo_Sequence
START WITH 1
MINVALUE 1
MAXVALUE 999999999
INCREMENT BY 1
CACHE 20;
2.触发器
CREATE OR REPLACE TRIGGER Tig_UserInfo_Insert
BEFORE INSERT ON UserInfo --插入动作触发器
FOR EACH ROW WHEN(new.id IS NULL) --id值为null时触发
BEGIN
select Tab_UserInfo_Sequence.nextval into :new.id from dual; --插入序列值到id值
END;
3.测试用例
INSERT INTO UserInfo(username, password) VALUES('aaa', '111');
INSERT INTO UserInfo(username, password) VALUES('bbb', '222');
INSERT INTO UserInfo(username, password) VALUES('ccc', '333');
查看表数据,结果如下:

4.END
至此,使用触发器设置主键自增已完成。
本文介绍如何在Oracle数据库中利用触发器实现数据表主键自增功能。通过创建序列和触发器,当插入新记录且ID为空时,系统自动填充序列生成的值。
1921

被折叠的 条评论
为什么被折叠?



