执行结果:

  序列已创建。

  步骤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