Oracle 创建表并设置主键自增

狂风中的少年 提交于 2019-11-30 17:51:55
--创建表
CREATE TABLE STUDENT(
ID NUMBER PRIMARY KEY,
NAME VARCHAR(200) NOT NULL,
SEX VARCHAR(200),
CREATE_DATE DATE);
--指定列注释
COMMENT ON COLUMN STUDENT.ID IS '学生ID';
COMMENT ON COLUMN STUDENT.NAME IS '学生姓名';
COMMENT ON COLUMN STUDENT.SEX IS '学生性别';
COMMENT ON COLUMN STUDENT.CREATE_DATE IS '创建日期';
--创建序列
CREATE SEQUENCE student_seq -- student_seq:序列名称
     INCREMENT BY 1 -- 每次增加1个
     START WITH 1 --从1开始计数
     NOMAXVALUE -- 不设置最大值
     NOCYCLE --直累加,不循环
     NOCACHE --不建立缓冲区
     
-- 创建触发器
CREATE OR REPLACE TRIGGER STUDENT_TRG -- STUDENT_TRG:触发器名称
  BEFORE INSERT ON STUDENT            -- STUDENT:触发的数据表
  FOR EACH ROW -- WHEN (new.ID is null) 设置主键存在时,不触发触发器
BEGIN
  SELECT STUDENT_SEQ.NEXTVAL INTO :NEW.ID FROM DUAL; --STUDENT_SEQ 序列名称
END;
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!