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数据库中创建了一个具有自增字段的表。这种方法广泛应用于需要唯一标识符的场景中,比如日志记录、用户注册等。
在上面的示例代码中,创建了一个名为 `Car_GUID` 的序列,用于生成自增字段 `GUID` 的值。 自增字段(Auto Increment)是指在插入数据时,自动将字段的值增加一单位。在上面的示例代码中,使用了序列 `Car_GUID` 来...
PostgreSQL 中可以通过 `SERIAL` 类型或者使用 `IDENTITY` 属性来创建自增字段。下面是一个使用 `SERIAL` 类型的例子: ```sql CREATE TABLE T1 ( id SERIAL NOT NULL ); ``` `SERIAL` 是一种特殊的数据类型,...
### Oracle 使用序列创建自增字段 在数据库设计与开发中,自增字段是十分常见的需求之一,尤其是在需要为每一行记录自动分配一个唯一编号的情况下。Oracle 数据库通过序列(Sequence)这一特性支持自增字段的实现。...
Trigger是Oracle中的一个数据库触发器,可以在特定的数据库事件(如INSERT、UPDATE、DELETE)发生时自动执行一段PL/SQL代码。在这里,我们创建了一个Before Insert触发器`trg_<tablename>`,它在插入新行前获取...
- 在表中插入新记录时,无需指定自增字段的值,触发器会自动为其分配序列的下一个值。 5. **验证**: - 查看表中的数据,确认自增字段是否按预期工作。 通过以上步骤,您可以在Oracle数据库中实现类似于SQL ...
Oracle 创建自增字段方法-ORACLE SEQUENCE 的简单介绍 Oracle SEQUENCE 是一种特殊的数据库对象,用于生成一系列唯一的数值,通常用于主键或其他需要唯一标识的字段。下面将详细介绍 Oracle 创建自增字段方法-...
为了在插入数据时能够自动获取自增ID,首先需要创建一个序列对象。 ##### 创建序列 根据给定的部分内容,我们可以看到一个示例序列的创建方式: ```sql CREATE SEQUENCE seq_atable MINVALUE 1 MAXVALUE ...
在SQL Server中,创建自增字段只需在创建表时指定`IDENTITY`属性,如: ```sql CREATE TABLE TABLE1 ( procid INT IDENTITY(1,1), ... ); ``` 而在Oracle中,需要额外的`SEQUENCE`和`TRIGGER`来达到相同效果...
Oracle在较新的12c版本中引入了一种新的语法,使得创建自增序列变得更加方便。这个特性被称为`IDENTITY`列,它允许我们在创建表时直接定义一个自动递增的字段。以下是对这个特性的详细说明: 首先,我们来看一下12c...
在Oracle数据库中,自增主键是一种非常实用且常见的设计模式,它能够确保表中的每一条记录都拥有一个唯一的标识符,这对于数据的管理和查询非常重要。本文将详细介绍如何在Oracle中实现自增主键的功能。 #### 创建...
这段代码定义了一个名为`tg_test`的触发器,在`TEST`表上进行插入操作之前,如果新行的`NID`字段为空,则自动为其分配序列`SEQ_TEST`的下一个值。 #### 三、使用自增主键 现在我们可以使用这个自增主键了。例如,...
在Oracle数据库系统中,主键(Primary Key)是表中的一个或一组字段,它们的值在整张表中是唯一的,用于唯一标识每一条记录。然而,与MySQL等其他数据库不同,Oracle并没有内置的自动递增(auto-increment)功能来...
触发器是 Oracle 中的一种机制,可以在特定的事件发生时执行特定的操作。例如,在插入数据时触发触发器,触发器可以将序列生成的数字插入到相应的字段中。 知识点五: 建立触发器 建立触发器的语法是:CREATE OR ...
以下是一个在 Oracle 中创建自增主键的详细步骤: 1. **创建序列**: Oracle 中的序列是一种可以生成唯一整数序列的对象。在这个例子中,我们可以创建一个名为 `seq.TableName` 的序列,其中 `TableName` 是表的...
以下将详细讲解如何在Oracle中创建自增字段sequence,并讨论其相关知识点。 首先,创建自增序列的基本语法如下: ```sql CREATE SEQUENCE sequence_name INCREMENT BY increment_value -- 自增步长,例如1 START ...
Oracle 数据库中,字段值自动加 1 是一个常见的需求,特别是在数据插入时需要自动生成唯一标识符的情况下。下面将详细介绍如何实现 Oracle 数据库字段值自动加 1。 首先,需要创建一个表来存储数据。在本示例中,...
先假设有这么一个表: 代码... 在oracle中sequence就是所谓的序列号,每次取的时候它会自动增加,一般用在需要按序列号排序的地方。 1、Create Sequence 你首先要有CREATE SEQUENCE或者CREATE ANY SEQUENCE权限, CREAT
在实际应用中,"Oracle数据库表序列ID自增生成器"可能是一个工具或脚本,简化了上述过程,自动为用户创建所需的序列和触发器。通过使用这样的工具,数据库管理员和开发人员可以更高效地管理他们的表结构,无需手动...