`

如何在ORACLE中创建一个自增字段

阅读更多
ORACLE SEQUENCE的简单介绍 
 

在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。 
1、Create Sequence 
你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限, 
CREATE SEQUENCE emp_sequence 
INCREMENT BY 1  -- 每次加几个 
START WITH 1   -- 从1开始计数 
NOMAXVALUE    -- 不设置最大值 
NOCYCLE     -- 一直累加,不循环 
CACHE 10; 

一旦定义了emp_sequence,你就可以用CURRVAL,NEXTVAL 
CURRVAL=返回 sequence的当前值 
NEXTVAL=增加sequence的值,然后返回 sequence 值 
比如: 
emp_sequence.CURRVAL 
emp_sequence.NEXTVAL 

可以使用sequence的地方: 
- 不包含子查询、snapshot、VIEW的 SELECT 语句 
- INSERT语句的子查询中 
- NSERT语句的VALUES中 
- UPDATE 的 SET中 

可以看如下例子: 
INSERT INTO emp VALUES 
(empseq.nextval, 'LEWIS', 'CLERK',7902, SYSDATE, 1200, NULL, 20); 

SELECT empseq.currval FROM DUAL; 

但是要注意的是: 
- 第一次NEXTVAL返回的是初始值;随后的NEXTVAL会自动增加你定义的INCREMENT BY值,然后返回增加后的值。CURRVAL 总是返回当前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否则会出错。一次NEXTVAL会增加一次SEQUENCE的值,所以如果你在同一个语句里面使用多个NEXTVAL,其值就是不一样的。明白? 

- 如果指定CACHE值,ORACLE就可以预先在内存里面放置一些sequence,这样存取的快些。cache里面的取完后,oracle自动再取一组到cache。 使用cache或许会跳号, 比如数据库突然不正常down掉(shutdown abort),cache中的sequence就会丢失. 所以可以在create sequence的时候用nocache防止这种情况。 

2、Alter Sequence 
你或者是该sequence的owner,或者有ALTER ANY SEQUENCE 权限才能改动sequence. 可以alter除start至以外的所有sequence参数.如果想要改变start值,必须 drop sequence 再 re-create . 
Alter sequence 的例子 
ALTER SEQUENCE emp_sequence 
  INCREMENT BY 10 
  MAXVALUE 10000 
  CYCLE   -- 到10000后从头开始 
  NOCACHE ; 


影响Sequence的初始化参数: 
SEQUENCE_CACHE_ENTRIES =设置能同时被cache的sequence数目。 

可以很简单的Drop Sequence 
DROP SEQUENCE order_seq;
分享到:
评论

相关推荐

    oracle里建一个自增字段示例

    ### Oracle里建一个自增字段示例 在Oracle数据库中,自增字段通常...通过上述步骤,我们成功地在Oracle数据库中创建了一个具有自增字段的表。这种方法广泛应用于需要唯一标识符的场景中,比如日志记录、用户注册等。

    Oracle中创建表,创建序列,创建自增字段,添加注释, 添加记录,添加触发器,提交

    在上面的示例代码中,创建了一个名为 `Car_GUID` 的序列,用于生成自增字段 `GUID` 的值。 自增字段(Auto Increment)是指在插入数据时,自动将字段的值增加一单位。在上面的示例代码中,使用了序列 `Car_GUID` 来...

    常用数据库的自增字段创建方法汇总

    PostgreSQL 中可以通过 `SERIAL` 类型或者使用 `IDENTITY` 属性来创建自增字段。下面是一个使用 `SERIAL` 类型的例子: ```sql CREATE TABLE T1 ( id SERIAL NOT NULL ); ``` `SERIAL` 是一种特殊的数据类型,...

    Oracle使用序列创建自增字段

    ### Oracle 使用序列创建自增字段 在数据库设计与开发中,自增字段是十分常见的需求之一,尤其是在需要为每一行记录自动分配一个唯一编号的情况下。Oracle 数据库通过序列(Sequence)这一特性支持自增字段的实现。...

    Oracle9i中建立自增字段的最新办法

    Trigger是Oracle中的一个数据库触发器,可以在特定的数据库事件(如INSERT、UPDATE、DELETE)发生时自动执行一段PL/SQL代码。在这里,我们创建了一个Before Insert触发器`trg_<tablename>`,它在插入新行前获取...

    创建oracle数据库中表的主键和自增

    - 在表中插入新记录时,无需指定自增字段的值,触发器会自动为其分配序列的下一个值。 5. **验证**: - 查看表中的数据,确认自增字段是否按预期工作。 通过以上步骤,您可以在Oracle数据库中实现类似于SQL ...

    Oracle创建自增字段方法-ORACLE SEQUENCE的简单介绍

    Oracle 创建自增字段方法-ORACLE SEQUENCE 的简单介绍 Oracle SEQUENCE 是一种特殊的数据库对象,用于生成一系列唯一的数值,通常用于主键或其他需要唯一标识的字段。下面将详细介绍 Oracle 创建自增字段方法-...

    Oracle插入数据时获取自增ID

    为了在插入数据时能够自动获取自增ID,首先需要创建一个序列对象。 ##### 创建序列 根据给定的部分内容,我们可以看到一个示例序列的创建方式: ```sql CREATE SEQUENCE seq_atable MINVALUE 1 MAXVALUE ...

    Oracle 实现类似SQL Server中自增字段的一个办法

    在SQL Server中,创建自增字段只需在创建表时指定`IDENTITY`属性,如: ```sql CREATE TABLE TABLE1 ( procid INT IDENTITY(1,1), ... ); ``` 而在Oracle中,需要额外的`SEQUENCE`和`TRIGGER`来达到相同效果...

    Oracle里的自增字段设置

    Oracle在较新的12c版本中引入了一种新的语法,使得创建自增序列变得更加方便。这个特性被称为`IDENTITY`列,它允许我们在创建表时直接定义一个自动递增的字段。以下是对这个特性的详细说明: 首先,我们来看一下12c...

    oracle中设置自增主键参考

    在Oracle数据库中,自增主键是一种非常实用且常见的设计模式,它能够确保表中的每一条记录都拥有一个唯一的标识符,这对于数据的管理和查询非常重要。本文将详细介绍如何在Oracle中实现自增主键的功能。 #### 创建...

    ORACLE自增主键设置方法

    这段代码定义了一个名为`tg_test`的触发器,在`TEST`表上进行插入操作之前,如果新行的`NID`字段为空,则自动为其分配序列`SEQ_TEST`的下一个值。 #### 三、使用自增主键 现在我们可以使用这个自增主键了。例如,...

    Oracle中主键自增实例

    在Oracle数据库系统中,主键(Primary Key)是表中的一个或一组字段,它们的值在整张表中是唯一的,用于唯一标识每一条记录。然而,与MySQL等其他数据库不同,Oracle并没有内置的自动递增(auto-increment)功能来...

    oracle实现属性的自增

    触发器是 Oracle 中的一种机制,可以在特定的事件发生时执行特定的操作。例如,在插入数据时触发触发器,触发器可以将序列生成的数字插入到相应的字段中。 知识点五: 建立触发器 建立触发器的语法是:CREATE OR ...

    Oracle主键自增的办法

    以下是一个在 Oracle 中创建自增主键的详细步骤: 1. **创建序列**: Oracle 中的序列是一种可以生成唯一整数序列的对象。在这个例子中,我们可以创建一个名为 `seq.TableName` 的序列,其中 `TableName` 是表的...

    Oracle创建自增字段sequence

    以下将详细讲解如何在Oracle中创建自增字段sequence,并讨论其相关知识点。 首先,创建自增序列的基本语法如下: ```sql CREATE SEQUENCE sequence_name INCREMENT BY increment_value -- 自增步长,例如1 START ...

    oracle数据库字段值自动加1

    Oracle 数据库中,字段值自动加 1 是一个常见的需求,特别是在数据插入时需要自动生成唯一标识符的情况下。下面将详细介绍如何实现 Oracle 数据库字段值自动加 1。 首先,需要创建一个表来存储数据。在本示例中,...

    Oracle创建自增字段–ORACLE SEQUENCE的简单使用介绍

    先假设有这么一个表: 代码... 在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。 1、Create Sequence 你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限, CREAT

    Oracle数据库表序列ID自增生成器

    在实际应用中,"Oracle数据库表序列ID自增生成器"可能是一个工具或脚本,简化了上述过程,自动为用户创建所需的序列和触发器。通过使用这样的工具,数据库管理员和开发人员可以更高效地管理他们的表结构,无需手动...

Global site tag (gtag.js) - Google Analytics