能够通过在 SQL 语句中使用 NEXTVAL 或 CURRVAL 运算符来訪问序列的值。必须用以 sequence.NEXTVAL 或sequence.CURRVAL 格式驻留在同一个数据库中的序列名称(或同义词)来限定 NEXTVAL 或 CURRVAL

表达式也能够用全部者名来限定序列,如 zelaine.myseq.CURRVAL。能够指定 sequence 的
SQL 标识或有效同义词(假设存在的话)。

在符合 ANSI 的数据库中。假设您不是全部者,必须用全部者名(owner.sequence)限定序列名。

要对序列使用 NEXTVAL 或 CURRVAL。必须对序列具有选择特权或对数据库具有 DBA 特权。

关于序列级特权的信息,请參阅 GRANT 语句。

使用 NEXTVAL

第一次訪问一个序列。在引用 sequence.CURRVAL 之前必须先引用 sequence.NEXTVAL。第一次引用NEXTVAL,返回序列的初始值。

后面每次引用 NEXTVAL,用已定义的 step 添加序列值并返回序列新的添加以后的值。

在一个 SQL 语句中仅仅能对给定的序列添加一次。

即使在一个语句中多次指定 sequence.NEXTVAL,序列也仅仅添加一次,所以每次 sequence.NEXTVAL 出如今同一 SQL 语句中返回同样的值。

除了在同一语句中多次出现这样的情况以外,每一个 sequence.NEXTVAL 表达式都会添加序列。无论后来是否提交或回滚当前事务。

假设在终于回滚的事务中指定 sequence.NEXTVAL,某些序列数可能被跳过。

使用 CURRVAL

不论什么对 CURRVAL 的引用返回指定序列的当前值,该值是最后一次对 NEXTVAL 的引用所返回的值。

用 NEXTVAL生成一个新值以后,能够继续使用 CURRVAL 訪问这个值。无论还有一个用户是否添加这个序列。

假设 sequence.CURRVAL 和 sequence.NEXTVAL 都出如今一个 SQL 语句中,则序列仅仅添加一次。在这样的情况下。每一个 sequence.CURRVAL 和 sequence.NEXTVAL 表达式都返回同样的值,无论在语句中sequence.CURRVAL 和 sequence.NEXTVAL 的顺序。

序列的并发訪问

序列总是在数据库中生成唯一值,即使当多个用户并发地引用同一序列时也没有可察觉的等待或锁定。

当多个用户使用 NEXTVAL 来增长序列时,每一个用户生成一个其他用户不可见的唯一值。

当多个用户并发地添加同一序列时,每一个用户看到的值是有差异的。比如,一个用户可能从一个序列生成一组值,如 146 和 8。而还有一个用户并发地从同一序列生成值 235 和 7

限制

NEXTVAL 和 CURRVAL 仅仅在 SQL 语句中有效。并不在 SPL 语句中直接有效。(可是使用 NEXTVAL 和CURRVAL 的 SQL 语句可用于 SPL 例程。

)下面限制应用于 SQL 语句中的这些运算符:

  • 必须对序列有选择特权。

  • 在 CREATE TABLE 或 ALTER TABLE 语句中,在下列上下文中不能指定 NEXTVAL 或 CURRVAL:
    • 在 DEFAULT 子句中
    • 在检查约束中。

  • 在 SELECT 语句中。下列上下文中不能指定 NEXTVAL 或 CURRVAL:
    • 使用 DISTINCT keyword时在投影列表中。
    • 在 WHERE、GROUP BY 或 ORDER BY 子句中
    • 在子查询中
    • 在 UNION 运算符结合 SELECT 语句时。

  • 在下列这些上下文中也不能指定 NEXTVAL 或 CURRVAL:
    • 在分段存储表达式中
    • 在对还有一个数据库中的远程序列对象的引用中。

演示样例

在下面的样例中,假设没有其他用户并发地訪问序列而且用户连续运行语句。

演示样例基于下列序列和表:

CREATE SEQUENCE seq_2
INCREMENT BY 1 START WITH 1
MAXVALUE 30 MINVALUE 0
NOCYCLE CACHE 10 ORDER; CREATE TABLE tab1 (col1 int, col2 int);
INSERT INTO tab1 VALUES (0, 0);

能够在 INSERT 语句的 values 子句中使用 NEXTVAL(或 CURRVAL),例如以下面演示样例中所看到的:

INSERT INTO tab1 (col1, col2)
VALUES (seq_2.NEXTVAL, seq_2.NEXTVAL)

在前面的样例中。数据库server把一个添加后的值(或序列的初始值。即 1)插入到表的 col1 和 col2 列。

能够在 UPDATE 语句的 SET 子句中使用 NEXTVAL(或 CURRVAL),例如以下面演示样例中所看到的:

UPDATE tab1
SET col2 = seq_2.NEXTVAL
WHERE col1 = 1;

在前面的样例中。seq_2 序列增长以后的值。即 2,替换了 col2 中 col1 等于 1 的值。

下面演示样例显示了怎样在 SELECT 语句的 Projection 子句中使用 NEXTVAL 和 CURRVAL:

SELECT seq_2.CURRVAL, seq_2.NEXTVAL FROM tab1;

在前面的演示样例中,数据库server从 CURRVAL 和 NEXTVAL 表达式返回两行添加后的值。和 4。对 tab1 的第一行。数据库server返回 CURRVAL 和 NEXTVAL 添加后的值 3;对 tab1 的第二行。它返回添加后的值 4

Oracle中NEXTVAL 和 CURRVAL的使用的更多相关文章

  1. oracle中的CURRVAL和NEXTVAL用法

    原文:https://blog.csdn.net/qianyiyiding/article/details/51592689  1.什么是sequence?其作用是什么? 在Oracle数据库中,什么 ...

  2. Oracle 中select XX_id_seq.nextval from dual 什么意思呢?

    说明 今天看别人的代码 ,遇见了 一条sql    select ctg_fault_list_id_seq.nextval from dual  不懂意思,然后就研究了下 dual :是oracle ...

  3. Oracle中的自动增长字段

    Oracle中的自动增长字段 Oracle 中不像MYSQL 和MSSQLServer 中那样指定一个列为自动增长列的方式,不过在Oracle中可以通过SEQUENCE序列来实现自动增长字段. 在Or ...

  4. oracle中的数据对象

    oracle中的数据对象有表.视图.索引.序列等 表的相关操作 1.创建表 方式一: 方式二:create table person( create table person1 id number(1 ...

  5. oracle中的dual表详解

    oracle中的dual表详解 1.DUAL表的用途 Dual 是 Oracle中的一个实际存在的表,任何用户均可读取,常用在没有目标表的Select语句块中 --查看当前连接用户 SQL> s ...

  6. 【转】Oracle中dual表的用途介绍

    原文:Oracle中dual表的用途介绍 [导读]dual是一个虚拟表,用来构成select的语法规则,oracle保证dual里面永远只有一条记录.我们可以用它来做很多事情. dual是一个虚拟表, ...

  7. ORACLE中dba,user,v$等开头的常用表和视图

    一.Oracle表明细及说明1.dba_开头表    dba_users           数据库用户信息    dba_segments    表段信息    dba_extents        ...

  8. oracle中sequence(自增序号)的用法

    转载:https://www.cnblogs.com/liuzy2014/p/5794928.html 在oracle中sequence就是序号,每次取的时候它会自动增加.sequence与表没有关系 ...

  9. 【Oracle】详解Oracle中的序列

    序列: 是oacle提供的用于产生一系列唯一数字的数据库对象. 自动提供唯一的数值 共享对象 主要用于提供主键值 将序列值装入内存可以提高访问效率 创建序列: 1.  要有创建序列的权限 create ...

随机推荐

  1. poi 处理空单元格

    http://poi.apache.org/spreadsheet/quick-guide.html 用google翻译 找到

  2. JQuery 全选 反选 获取Table 中指定td的元素值

    //全选 function initTableCheckbox() { var $thr = $('table thead tr'); var $checkAllTh = $('<th>& ...

  3. ASE code search -- 第二次结对编程作业

    baseline 复现 baseline模型 我们再这次实验中选择了deep code search方法作为了解并复现.下面介绍一下这两种方法 deep code search 模型的结构在论文中已经 ...

  4. 【记录】API Gateway作用? 与过滤器的区别?Nginx与Zuul区别?

    网关(gateway)的作用: 网关可以拦截客户端所有请求,对该请求进行权限控制.负载均衡.日志管理.接口调用监控等 过滤器与网关的区别是什么? 过滤器是拦截单个tomcat服务器请求. 网关是拦截整 ...

  5. ubuntu18.4 搭建lamp环境

    一.Apache2 web服务器的安装: 可以先更新一下服务器(可选) 1.sudo apt update             # 获取最新资源包 2.sudo apt upgrade       ...

  6. sqldeveloper全部导出

    点击Tools--Export User Objects 这种方式可以导出当前用户拥有的所有对象,包括表.视图.触发器.同义词等等,对于表,只能导出表结构(建表语句),不能导出数据, 选中要导出的对象 ...

  7. Translucent System Bar 的最佳实践

    转自:http://www.jianshu.com/p/0acc12c29c1b 近几天准备抽空总结Android一些系统UI的实践使用,于是开始动手建了一个库 AndroidSystemUiTrai ...

  8. C++使用cout输出中文,打印出来是乱码

    windows下的控制台使用的是gbk编码.你输出的是unicode.在Vs中更改高级保存选项,将Unicode改为GB类型(比如GB18030)

  9. Java中IO流之字符流

    我们有了字节流,为什么还需要字符流? 字符的底层是 字节 + 编码表 = 字符,字符是人能看懂的信息. 字符流在使用的时候,会以字节流为基础,把字节写入缓冲区,在缓冲区内根据编码类型(UTF-8,GB ...

  10. vue中的$nextTick的常用思路

    Vue 实现响应式并不是数据发生变化之后 DOM 立即变化,而是按一定的策略进行 DOM 的更新. $nextTick 是在下次 DOM 更新循环结束之后执行延迟回调,在修改数据之后使用 $nextT ...