序列(SEQUENCE)是序列号生成器,可以为表中的行自动生成序列号,产生一组等间隔的数值(类型为数字)。其主要的用途是生成表的主键值,可以在插入语句中引用,也可以通过查询检查当前值,或使序列增至下一个值。

  创建序列需要CREATE SEQUENCE系统权限。序列的创建语法如下:

  CREATESEQUENCE序列名
  [INCREMENTBYn]
  [STARTWITHn]
  [{MAXVALUE/MINVALUEn|NOMAXVALUE}]
  [{CYCLE|NOCYCLE}]
  [{CACHEn|NOCACHE}];

  其中:

  INCREMENT BY 用于定义序列的步长,如果省略,则默认为1,如果出现负值,则代表序列的值是按照此步长递减的。

  START WITH 定义序列的初始值(即产生的第一个值),默认为1。

  MAXVALUE 定义序列生成器能产生的最大值。选项NOMAXVALUE是默认选项,代表没有最大值定义,这时对于递增序列,系统能够产生的最大值是10的27次方;对于递减序列,最大值是-1。

  MINVALUE定义序列生成器能产生的最小值。选项NOMAXVALUE是默认选项,代表没有最小值定义,这时对于递减序列,系统能够产生的最小值是?10的26次方;对于递增序列,最小值是1。

  CYCLE和NOCYCLE 表示当序列生成器的值达到限制值后是否循环。CYCLE代表循环,NOCYCLE代表不循环。如果循环,则当递增序列达到最大值时,循环到最小值;对于递减序列达到最小值时,循环到最大值。如果不循环,达到限制值后,继续产生新值就会发生错误。

  CACHE(缓冲)定义存放序列的内存块的大小,默认为20。NOCACHE表示不对序列进行内存缓冲。对序列进行内存缓冲,可以改善序列的性能。

  删除序列的语法是:

  DROPSEQUENCE序列名;

  删除序列的人应该是序列的创建者或拥有DROP ANY SEQUENCE系统权限的用户。序列一旦删除就不能被引用了。

  序列的某些部分也可以在使用中进行修改,但不能修改SATRT WITH选项。对序列的修改只影响随后产生的序号,已经产生的序号不变。修改序列的语法如下:

  创建和删除序列

  例1:创建序列:

  CREATE SEQUENCE ABC INCREMENT BY 1 START WITH 10 MAXVALUE 9999999 NOCYCLE NOCACHE;

  执行结果:

  序列已创建。

  步骤2:删除序列:

  DROP SEQUENCE ABC;

  执行结果:

  序列已丢弃。

  说明:以上创建的序列名为ABC,是递增序列,增量为1,初始值为10。该序列不循环,不使用内存。没有定义最小值,默认最小值为1,最大值为9 999 999。

  序列的使用

  如果已经创建了序列,怎样才能引用序列呢?方法是使用CURRVAL和NEXTVAL来引用序列的值。

  在编号的过程中,产生间隙的原因多种多样。如果一个存储过程从一个序列中挑选某个数字,定为本地变量,但是从来不用它,这个数字就丢失了。它将不能再返回到原序列中,结果就造成数值序列中存在一个间隙。关系型数据库模型中不必担心这一点。但是有时候人们在意这一点,这些人想知道是哪些数字丢失了。

  调用NEXTVAL将生成序列中的下一个序列号,调用时要指出序列名,即用以下方式调用:

  序列名.NEXTVAL

  CURRVAL用于产生序列的当前值,无论调用多少次都不会产生序列的下一个值。如果序列还没有通过调用NEXTVAL产生过序列的下一个值,先引用CURRVAL没有意义。调用CURRVAL的方法同上,要指出序列名,即用以下方式调用:

  序列名.CURRVAL.

  产生序列的值。

  步骤1:产生序列的第一个值:

  SELECT ABC.NEXTVAL FROM DUAL;

  执行结果:

  NEXTVAL
  ------------------
  10

  步骤2:产生序列的下一个值:

  SELECT ABC.NEXTVAL FROM DUAL;

  执行结果:

  NEXTVAL
  -------------------
  11

  产生序列的当前值:

  SELECT ABC.CURRVAL FROM DUAL;

  执行结果:

  CURRVAL
  --------------------
  11

  说明:第一次调用NEXTVAL产生序列的初始值,根据定义知道初始值为10。第二次调用产生11,因为序列的步长为1。调用CURRVAL,显示当前值11,不产生新值。Oracle的解析函数为检查间隙提供了一种要快捷得多的方法。它们使你在使用完整的、面向集合的SQL处理的同时,仍然能够看到下一个行(LEAD)或者前一行(LAG)的数值。

  查看序列

  同过数据字典USER_OBJECTS可以查看用户拥有的序列。

  通过数据字典USER_SEQUENCES可以查看序列的设置。

  例:查看用户的序列:

  SELECTSEQUENCE_NAME,MIN_VALUE,MAX_VALUE,INCREMENT_BY,LAST_NUMBERFROM
  USER_SEQUENCES;

  执行结果:

  SEQUENCE_NAME MIN_VALUE MAX_VALUE INCREMENT_BY LAST_NUMBER

  说明:当前用户拥有两个序列:ABC和BOOKID。

转载于:https://www.cnblogs.com/sharkfin08/archive/2011/03/08/1976953.html

Oracle数据库中序列用法讲解(转)相关推荐

  1. Oracle数据库之rownum,ORACLE数据库中Rownum用法详解

    ORACLE 中ROWNUM用法总结! 对于 Oracle 的 rownum 问题,很多资料都说不支持>,>=,=,between...and,只能用以上符号(,& gt;=,=, ...

  2. Oracle数据库中序列(SEQUENCE)的用法详解

    http://database.51cto.com/art/201108/280742.htm 在Oracle数据库中,什么是序列呢?它的用途是什么?序列(SEQUENCE)其实是序列号生成器,可以为 ...

  3. ORACLE数据库中HAVING用法笔记

    对数据聚合后计数 以自建的一张成绩表CSDN_HAVING作为示例,有三个字段NAME.SUBJECT.SCORE,分别表示"姓名"."学科"."成绩 ...

  4. oracle中md5算法,oracle数据库中存储过程使用MD5算法加密

    一.技术点 1. DBMS_OBFUSCATION_TOOLKIT.MD5 DBMS_OBFUSCATION_TOOLKIT.MD5是MD5编码的数据包函数,但偶在使用select DBMS_OBFU ...

  5. oracle中call用法,Oracle数据库中 call 和 exec的区别

    Oracle数据库中 call 和 exec的区别 今天发现了一个小东西,觉得很有意思,查找了一些资料,跟大家分享一下: 在sqlplus中: 在第三方提供的工具(如:plsqldev) 总结: ex ...

  6. oracle12c order by,oracle 数据库中order by 的一些高级用法

    oracle数据库中order by用法 oracle数据库中order by的一些高级用法 现有一个表,表内容如下: 以下的操作都是对该表进行的操作 1.按照名称排序(默认为升序) 实现代码: se ...

  7. oracle 数据库中order by 的一些高级用法

    oracle数据库中order by用法 oracle数据库中order by的一些高级用法 现有一个表,表内容如下: 以下的操作都是对该表进行的操作 1.按照名称排序(默认为升序) 实现代码: se ...

  8. Oracle数据库中escape、in、between...and...用法举例

    Oracle数据库中escape.in.between-and-用法举例 1.escape是用来转译的,当表A 的name字段 中存在字符'%',而且查询第二位是 '%',就要用到模糊查询,但是'%' ...

  9. oracle数据库序列码,oracle 数据库中的序列

    序列是什么,通俗点说,序列就是按照一定顺序进行排列,序列会自动给你递增,生成唯一的序列号: oracle数据库不同于sqlServer数据库,oracle数据库中是没有自增长列,使用的是sequenc ...

  10. Oracle数据库中SQL语句用法(一)

    Copyright © 2019 @Linyer. All Rights Reserved 下接Oracle数据库中SQL语句用法(二)[点击以查看] 目录 第1章:编写基本的SQL SELECT语句 ...

最新文章

  1. 定时分量和直流分量_交直流输入的RC电路分析
  2. Spark RDD-行动算子
  3. 谈谈对APC的一点理解
  4. php 四舍五入百位,php取整函数ceil,floor,round,intval函数的区别
  5. mysql gtid坑_通过mysqlbinlog --skip-gtids恢复后再备份可能造成的坑
  6. uilabel 自适应
  7. CWnd的派生类-3、CDialog类
  8. ntent action大全
  9. 商汤发布L4级接驳小巴和智能路侧感知解决方案,加速V2X产业创新
  10. 4.4系统,拍照-裁剪,resultCode返回0
  11. 计算机组成原理pdf在线阅读,计算机组成原理计算机组成原理.pdf
  12. NoSQL数据库的安装和使用
  13. c语言:查ascii码值
  14. 免费在excel密码破解--超好用
  15. JavaScript系列(2)内置对象:Date
  16. 谈谈Java对象的生命周期
  17. 关于递归算法设计的思考
  18. 独立显卡linux安装教程,linux 安装meshlab并且指定使用独立显卡
  19. 阿萨德阿斯顿的的点点滴滴
  20. 致诸位使用和支持火鸟字幕合并器的朋友

热门文章

  1. Ubuntu下编译运行C#——mono tools
  2. 开源项目也要讲注意力经济
  3. 【零开始】怎样购买、配置服务器及发布网站(页)?
  4. 用存储过程DataFactory准备测试数据
  5. 中兴ZTE ZXR10系列交换机2818S固件以及更新方法
  6. 组件Button的简单用法
  7. 注册表系列之恶作剧之吻
  8. String replaceAll 方法的问题?
  9. Linux下修改PATH的方法
  10. 13.深入分布式缓存:从原理到实践 --- 缓存在社交网络Feed系统中的架构实践