Oracle实现主键字段自增

Posted 睡竹

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Oracle实现主键字段自增相关的知识,希望对你有一定的参考价值。

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

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

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

方式一:Identity Columns新特性自增

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

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

  1. generated by default as IDENTITY
  2. generated 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(序列)详解_睡竹的博客-CSDN博客Oracle中sequence(序列)详解cache的作用及优缺点https://blog.csdn.net/weixin_42675423/article/details/127101723

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

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

--创建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问题:

如图:

重新打开页签:

如下:

方式四:创建自增序列,插入语句(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

Ef DbMigration 非主键字段 怎么设置为自增

参考技术A 按如下方法: 1、创建表 create table t5 (id int auto_increment,name varchar(20) primary key,key(id)); 其中name字段是主键,而id字段则是自增字段。 2、试插入数据: insert into t5 (name) values ('a'); 执行结果: 可以看出第一次,id字...3355本回答被提问者采纳 参考技术B 一、一个tomcat部署多个应用的方法: 在conf/server.xml配置文件中,有这样的标签: …… 默认只有一个 你复制一份儿,但host标签必须在engine标签之内。 #### Tomcat配置server.xml简单说明 ########### #这里可设置默认虚拟主机名 #connector是...

以上是关于Oracle实现主键字段自增的主要内容,如果未能解决你的问题,请参考以下文章

oracle数据库,表中有id(自增字段,主键), insert 语句插入一条记录后要求,返回当前插入记录的id値。

Ef DbMigration 非主键字段 怎么设置为自增

oracle设置主键自增

oracle数据库中的表设置主键自增

oracle自增主键从多少开始

oracle 实现 自增主键功能