Oracle数据库主键自增

Oracle数据库主键自增

在学习mysql时,我们很容易通过auto_increment就能实现主键自增的功能,但是在Oracle数据库中,是没有这个关键字的,所以也不能通过这样来实现主键自增。下面我就为大家介绍两种实现主键自增的方法。

两种方法的基础都有一个概念就是序列(sequence)的概念,一种是利用序列显式调用的方式去实现主键自增,另一种是通过序列触发器(trigger)来实现主键自增。

/*1.利用序列主键自增*/

  1. 第一步、创建表

--创建表,主键为ID

CREATE TABLE YFF (

ID INT primary key ,

NAME VARCHAR2(10)

);

--创建表的格式

CREATE TABLE 表名(

字段名 字段类型(可以加一些约束,例如主键约束),

字段名 字段类型

)

  1. 第二步、创建序列

--创建序列

create sequence seq_yff

start with 1

increment by 1;

--创建序列的格式

create sequence 序列名称

start with 开始数字

increment by 增长数字

minvalue 最小值

maxvalue 最大值

cycle 是否循环(cycle为循环,nocycle为不循环)

nocache  不使用缓存

  1. 关于序列的其他重要操作

--查询序列(利用nextval查询序列下一次的值)

select seq_yff.nextval from dual;

--查询序列的格式

Select 序列名.nextval from dual

(dual为伪表,当我们不需要从具体的表来取得表中数据,而是单纯地

得到一些我们想得到的信息,就可以使用伪表)

注意:这里第一次执行这条查询语句得到结果为1,再执行得到2,第一种实现主键自增的方法就是使用序列名.nextval使得值一直增加的

--删除序列()

DROP SEQUENCE seq_yff;

注意:序列和表不是连接在一起的,当序列创建之后,用在这个表之后,我将该表删除,但是序列的值还是停留在之前的值上,所以需要注意这个问题

  1. 第三步、利用序列+显式化调用 进行自增

insert into YFF values (seq_yff.nextval,‘张三‘);

insert into YFF values (seq_yff.nextval,‘张三‘);

select * from YFF;

--2利用序列+触发器调用 进行主键自增

此处已经表和序列都用第一种方法中使用过的

 第一步、在表和序列创建好之后,创建触发器

--创建触发器

create or replace trigger tri_yff_insert

before insert on YFF

referencing old as old new as new

for each row

begin

select seq_yff.nextval

into :new.ID

from dual;

end tri_yff_insert;

--创建触发器格式

create [or replace] tigger 触发器名

触发时间 触发事件

on 表名

[for each row]

begin

pl/sql语句

end

--解释上面的触发器语句

create or replace trigger tri_yff_insert    创建触发器并命名

before insert on YFF              触发时间为向表YFF中插入时

referencing old as old new as new

for each row      对表的每一行触发一次,否则只对整表执行一次

begin

select seq_yff.nextval

into :new.ID

from dual;

end tri_yff_insert;

  1. 其他对触发器的操作

--查询表中触发器

select * from all_triggers WHERE table_name=‘YFF‘

--删除触发器

drop trigger tri_yff_insert;

  1. 第二步、插入数据

insert into  YFF (ID,Name) values(100,‘李四‘);

insert into  YFF (Name) values(‘李四‘);

--不管给不给主键赋值,这里触发器都会使得主键值为序列的值

原文地址:https://www.cnblogs.com/YffCeShi/p/12239076.html

时间: 2024-07-30 16:22:52

Oracle数据库主键自增的相关文章

数据库主键自增插入显示值

SQL Server 2008 数据库主键自增插入显示值 前几天在工作的时候遇到在删除数据库中表的数据的时候,删除之后,重新添加的数据没有得到原来的数据的id值(表中id为主键,且设置为自增) ,使用的是SQL Server 2008 ,现在已解决,和大家分享一下! 具体情况: 1.建立表t_test,设置主键自增,如下图 2.向表中插入数据 由于表中的主键字段id为自增在插入的时候不需要指定显示插入,所以Sql 语句为 <span style="font-size:24px;"

oracle 数据库主键自动增长sql

我们都知道,在MySQL中,要实现主键的自动递增非常简单.只需要在主键定义的后面加上auto_increment即可, 但是在Oracle中就不是这样,需要分几步来完成 1.建立一个表 create table 户口本  (    户号                   INTEGER                         not null,    户别                   CHAR(20)                        not null,    户主

oracel数据库主键自增

-- Create sequence create sequence FILE_ID_SEQ   主键名(自增列) minvalue 1         起始 maxvalue 99999     最大值 start with 10100     开始于 increment by 1      增量 cache 20;           告诉缓存大小 Oracel中插入自增

数据库主键

在我们的数据库设计中,不可逃避的就是数据库表的主键,可能有很多朋友没有深入思考过,主键的设计对整个数据库的设计影响很大,因此我们不得不要重视起来. 主键的必要性 : 在有些数据库中,虽然主键不是必需的,但最好为每个表都设置一个主键,不管是单主键还是复合主键.它存在代表着表结构的完整性,表的记录必须得有唯一区分的字段,主键主要是用于其他表的外键关联,以及本记录的修改与删除. 主键的无意义性 : 在开发过程中,读者可能会看到将一些表使用有意义的字段表示主键,例如"用户登录信息表"将&quo

数据库主键的设计和思考

转载至:http://blog.csdn.net/likika2012/article/details/9949949 1. 何谓数据库主键 数据库主键是指表中一个列或列的组合,其值能唯一地标识表中的每一行.这样的一列或多列称为表的主键,通过它可强制表的实体完整性.当创建或更改表时可通过定义 PRIMARY KEY约束来创建主键.一个表只能有一个 PRIMARY KEY 约束,而且 PRIMARY KEY 约束中的列不能接受空值.由于 PRIMARY KEY约束确保唯一数据,所以经常用来定义标识

关于数据库主键的选择

数据库主键的选择 (原创) 工作了这么多年什么数据库的主键都用过,各种项目各种主键的变更,硬伤等等的问题都遇见过. 关与主键首先不要整个系统只使用一种方式的主键,要彻底吃透业务需求,根据需求考虑每张表的主键要怎么设计能给你带来最大的收益. 数据库常用的主键常用的四种:自增编号.Guid.自定义唯一.联合主键. 关于数据库主键的设计,如果设计的合理,会给整个系统带来很多优势.例如:降低开发难度少写很多代码.数据库检索效率.开移植性.可扩展性.可维护性.易读性等...对与主键来说,没有最好的,只有最

闲谈系列之一——数据库主键GUID

昨日一个行内兄弟由于工作调动要派到某二线城市工作,虽然有高额工资和补助的诱惑但也难以释怀离京蛋蛋的忧桑,约好晚上到老聚点道个别.主要是聊(chui)聊(chui)前(niu)程(bi),几瓶夺命大绿棒子下肚,这货问起我现在项目的情况(操蛋的技术控!),我简单的说了一下架子和数据库,果然在数据库主键上出现了分歧,在他心里主键就是应该是妥妥的自增整型,对于我的GUID无法容忍,并指出GUID不连续.效率低下.blablabla,最后我说了一下我的解决方案总算得到了一定程度的肯定吧... 对于程序猿来

关系型数据库主键总结

在基于关系型数据库设计时候,通常要为每张表指定一个主键,所谓主键就是能够唯一标识表中某一行记录的属性或属性组,一个表只能有一个主键,但可以 有多个候选索引.因为主键可以唯一标识某一行记录,所以可以确保执行数据更新.删除.修改时不出现错误.当然,其它字段可以辅助我们在执行这些操作时消除 共享冲突,不是本文讨论的重点,不再赘述.主键除了上述作用外,常常与外键构成参照完整性约束,防止出现数据不一致.所以数据库在设计时,主键起到了很重 要的作用.常见的数据库主键选取方式有: 自动增长式.手动增长式 .U

数据库主键到底是用自增长(INT)好还是UUID好

其实针对使用自增长还是UUID,大家讨论最多的就是速度和存储空间,这里我加入了安全性和分布式,具体对比如下: 使用自增长做主键的优点:1.很小的数据存储空间2.性能最好3.容易记忆使用自增长做主键的缺点:1.如果存在大量的数据,可能会超出自增长的取值范围2.很难(并不是不能)处理分布式存储的数据表,尤其是需要合并表的情况下3.安全性低,因为是有规律的,容易被非法获取数据使用GUID做主键的优点:1.它是独一无二的,出现重复的机会少2.适合大量数据中的插入和更新操作,尤其是在高并发和分布式环境下3