oracle添加数据时主键自动增长
CREATE TABLE STUDENT( --创建学生表
ID NUMBER(10) PRIMARY KEY, --主键ID
SNAME VARCHAR2(20),
);
此时给学生表添加数据时 必须指定id
INSERT INTO STUDENT VALUES(1,‘Tom‘);
下面用触发器和序列结合使得添加数据时id自动增长 不要指定了
--创建序列
CREATE SEQUENCE SEQ_STU
INCREMENT BY 1 ID每次自增几
START WITH 1 ID从几开始自增
MAXVALUE 99999 ID的最大值
MINVALUE 1; ID的最小值
--创建触发器 添加数据的时候id自增
CREATE OR REPLACE TRIGGER TIGGER_STU
BEFORE
INSERT ON STUDENT
FOR EACH ROW
WHEN(NEW.ID IS NULL)
BEGIN
SELECT SEQ_STU.NEXTVAL INTO:NEW.ID FROM DUAL;
END;
触发器创建好之后就可以这样添加数据了
INSERT INTO STUDENT VALUES(null,‘Tom‘);
ID可以为空 添加到数据库时 oracle会自动调用该触发器 更具序列 往后自增
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。