技术开发 频道

Oracle数据库中序列用法讲解

        序列的使用

  如果已经创建了序列,怎样才能引用序列呢?方法是使用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可以查看序列的设置。

  例:查看用户的序列:

  SELECT SEQUENCE_NAME,MIN_VALUE,MAX_VALUE,INCREMENT_BY,LAST_NUMBER FROM
  USER_SEQUENCES;

  执行结果:

  SEQUENCE_NAME MIN_VALUE MAX_VALUE INCREMENT_BY LAST_NUMBER

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

 

 

0
相关文章