Oracle实现主键字段自增的四种方式(oracle创建主键自增)这样也行?

随心笔谈2年前发布 编辑
151 0
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买



目录Oracle实现主键自增有4种方式:方式一:Identity Columns新特性自增准备工作:方式二:创建自增序列,创建表时,给主键字段默认使用自增序列方式三:创建自增序列,使用触发器使主键自增方式四:创建自增序列,插入语句(insert)时,使用自增序列代替值总结:

Identity Columns新特性自增(Oracle版本≥12c)创建自增序列,创建表时,给主键字段默认使用自增序列创建自增序列,使用触发器使主键自增创建自增序列,插入语句(insert)时,使用自增序列代替值

数据库表名称为:userinfo(不能使用user,user为Oracle关键字)

该种方式要求Oracle版本≥12c

在自增字段后使用以下2种语句的1种:

generated by default as IDENTITYgenerated always as identity

建表语句:

CREATE TABLE userinfo (
id number(11) generated by default as IDENTITY,–使用自增功能
name varchar2(20) ,
age number(3)
)

 测试:

INSERT INTO USERINFO (name,age) VALUES(‘张三’,18)

结果:

该种方式很简单,底层原理其实和下面3种方式相似,只是Oracle帮我们省去了多余的操作。

以下是剩余的3种方式,都用共同的特点(先创建自增序列): 

必须先创建自增序列:

–设置自增序列,名称为”seq_userinfo”,名字任意命名
create sequence seq_userinfo
increment by 1 –每次+1
start with 1 –从1开始
nomaxvalue –不限最大值
nominvalue –不限最小值
cache 20; –设置取值缓存数为20

sequence各个参数详解,可以参考这边文章:

Oracle中sequence(序列)详解

建表语句,设置自增字段默认使用自增序列(推荐该方式):

–创建userinfo表
CREATE TABLE userinfo (
id number(11) DEFAULT seq_userinfo.nextval, –“seq_userinfo”为自增序列名称
name varchar2(20) ,
age number(3)
);

测试:我使用的是DBeaver软件:

如图:

 注意:新增了一条数据,点击保存,该软件并不会立刻自动显示生成的ID,我们需要关闭当前页签,再打开就可以看到自增的ID

如下:

建表语句:

–创建userinfo表
CREATE TABLE userinfo (
id number(11) not null,
name varchar2(20) ,
age number(3)
);

创建触发器(只需要注意注释的位置):

–创建触发器,名称为”deptinfo_TRIGGER”,名字任意命名
create or replace trigger userinfo_TRIGGER
before insert on userinfo –“userinfo”为表名称
for each row
begin
select seq_userinfo.nextval into :new.id from dual; –1、”seq_userinfo”为自增序列名称 2、这里的id是你需要自增的序列
end userinfo_TRIGGER; –“userinfo_TRIGGER”为触发器名称

测试:跟方式1测试一样,会存在不显示ID问题:

如图:

重新打开页签:

如下:

建表语句:

–创建userinfo表
CREATE TABLE userinfo (
id number(11) not null,
name varchar2(20) ,
age number(3)
);

在插入语句中,自增的字段(ID),使用自增序列去代替

如下:

INSERT INTO userinfo(id,name,age) VALUES(seq_userinfo.nextval,’睡竹’,18);

注意:方式三与MySQL、微软的SQL server的自增方式是一样的!

运行结果:

 对后台系统开发来说:

方式1和方式2最方便

方式3还需要新加一个触发器,不推荐

方式4类似于方式2,但是对Java程序而言,mybatis的xml需要显式的指定触发器,不够友好

附上删除触发器和自增序列的语句:

–删除自增序列,”seq_userinfo”为自增序列的名称
drop sequence seq_userinfo
–删除触发器,”userinfo_TRIGGER”为触发器名称
drop trigger userinfo_TRIGGER

到此这篇关于Oracle实现主键字段自增的四种方式的文章就介绍到这了,更多相关Oracle主键字段自增内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:Oracle创建主键自增表(sql语句实现)及触发器应用Oracle数据库中创建自增主键的实例教程Oracle 创建主键自增表示例代码Oracle 触发器实现主键自增效果oracle数据库表实现自增主键的方法实例

© 版权声明

相关文章