Oracle实现主键字段自增的方式有哪些

网友投稿 588 2023-11-04

***实现主键字段自增的方式有哪些

今天小编给大家分享一下***实现主键字段自增的方式有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

***实现主键字段自增的方式有哪些

***实现主键自增有4种方式:

Identity Columns新特性自增(***版本≥12c)

创建自增序列,创建表时,给主键字段默认使用自增序列

创建自增序列,使用触发器使主键自增

创建自增序列,插入语句(insert)时,使用自增序列代替值

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

方式一:Identity Columns新特性自增

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

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

generated by default as IDENTITY

generated always as identity

建表语句:

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

 测试:

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

结果:

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

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

准备工作:

必须先创建自增序列:

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

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

***中sequence(序列)详解

方式二:创建自增序列,创建表时,给主键字段默认使用自增序列

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

--创建userinfo表 CREATE TABLE userinfo (   id number(11)  DEFAULTseq_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问题:

如图:

重新打开页签:

如下:

方式四:创建自增序列,插入语句(insert)时,使用自增序列代替值

建表语句:

--创建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

以上就是“***实现主键字段自增的方式有哪些”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:MySQL5.5版本安装失败怎么解决
下一篇:MySQL数据库如何改名
相关文章