数据库作为一个系统的核心,数据库设计的1NF就是一个表结构必须有唯一约束也就是主键,Oracle数据库本身没有自增机制,不像MySQL直接使用关键字AUTO_INCREMENT自动加一,所以需要我们去自己来实现,下面有几种实现的方式
一、序列化+触发器
第一步在表结构完整的情况下创建一个序列
CREATE SEQUENCE SEQ_NAME INCREMENT BY 1 MINVALUE 1 MAXVALUE 9999999999999999 START WITH 1 CACHE 20
第二部创建触发器
CREATE OR REPLACE TRIGGER TRIGGER_NEW BEFORE INSERT ON TABLE_NAME REFERENCING OLD AS "OLD" NEW AS "NEW" FOR EACH ROW ENABLE WHEN (NEW.ID IS NULL) BEGIN SELECT SEQ_NEW INTO : NEW.ID FROM DUAL END
二、序列+显示调用
同样先创建触发器
CREATE SEQUENCE SEQ_NAME INCREMENT BY 1 MINVALUE 1 NOMAXVALUE START WITH 1 NOCYCLE NOCACHE
下面显示调用
INSERT INTO TABLE_NAME VALUES(SEQ_NAME.NEXTVAL)
三、先指定主键值,查询此表最大值一次加一
INSERT INTO TABLE_NAME VALUES(SELECT MAX(ID)+1 ID FROM TABLE_NAME2)
当然第三种方式局限性很大,也可以在代码中操作不用SQL语句来累加,因为代码的执行速度要远比sql语句代码执行的速度快的多的多
注:
查看当前序列的值
SELECT SEQ_NAME.CURRVAL FROM DUAL
查看当前序列的下一个值
SELECT SEQ_NAME.NEXTVAL FROM DUAL
dual为Oracle里面虚拟的表,并不真实存在
原文地址:https://www.cnblogs.com/LiuFqiang/p/11826659.html
时间: 2024-10-29 03:01:24