快捷搜索:

Oracle数据库中序列用法讲解

序列(SEQUENCE)是序列号天生器,可以为表中的行自动天生序列号,孕育发生一组等距离的数值(类型为数字)。其主要的用途是天生表的主键值,可以在插入语句中引用,也可以经由过程查询反省当前值,或使序列增至下一个值。

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

CREATE SEQUENCE 序列名

[INCREMENT BY n]

[START WITH n]

[{MAXVALUE/ MINVALUE n|NOMAXVALUE}]

[{CYCLE|NOCYCLE}]

[{CACHE n|NOCACHE}];

INCREMENT BY 用于定义序列的步长,假如省略,则默觉得1,假如呈现负值,则代表序列的值是按照此步长递减的。

START WITH 定义序列的初始值(即孕育发生的第一个值),默觉得1。

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

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

CYCLE和NOCYCLE 表示当序列天生器的值达到限定值后是否轮回。CYCLE代表轮回,NOCYCLE代表不轮回。假如轮回,则当递增序列达到最大年夜值时,轮回到最小值;对付递减序列达到最小值时,轮回到最大年夜值。假如不轮回,达到限定值后,继承孕育发生新值就会发生差错。

CACHE(缓冲)定义寄放序列的内存块的大年夜小,默觉得20。NOCACHE表示纰谬序列进行内存缓冲。对序列进行内存缓冲,可以改良序列的机能。

删除序列的语法是:

DROP SEQUENCE 序列名;

此中:

删除序列的人应该是序列的创建者或拥有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可以查看序列的设置。

例:查看用户的序列:

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。

您可能还会对下面的文章感兴趣: