Oracle、DB2、PostgreSQL之Sequence總結(jié)

 

Sequence是數(shù)據(jù)庫(kù)系統(tǒng)按照一定規(guī)則自動(dòng)增加的數(shù)字序列。這個(gè)序列一般作為代理主鍵(因?yàn)椴粫?huì)重復(fù)),沒(méi)有其他任何意義。

Sequence是數(shù)據(jù)庫(kù)系統(tǒng)的特性,有的數(shù)據(jù)庫(kù)有Sequence,有的沒(méi)有。比如Oracle、DB2、PostgreSQL數(shù)據(jù)庫(kù)有Sequence,MySQL、SQL Server、Sybase等數(shù)據(jù)庫(kù)沒(méi)有Sequence。

根據(jù)我個(gè)人理解,Sequence是數(shù)據(jù)中一個(gè)特殊存放等差數(shù)列的表,該表受數(shù)據(jù)庫(kù)系統(tǒng)控制,任何時(shí)候數(shù)據(jù)庫(kù)系統(tǒng)都可以根據(jù)當(dāng)前記錄數(shù)大小加上步長(zhǎng)來(lái)獲取到該表下一條記錄應(yīng)該是多少,這個(gè)表沒(méi)有實(shí)際意義,常常用來(lái)做主鍵用,非常不錯(cuò),呵呵,不過(guò)很郁悶的各個(gè)數(shù)據(jù)庫(kù)廠商尿不到一個(gè)壺里--各有各的一套對(duì)Sequence的定義和操作。在此我對(duì)常見(jiàn)三種數(shù)據(jù)庫(kù)的Sequence的定義和操作做一個(gè)對(duì)比和總結(jié),以便日后查看。

 

一、定義Sequence

定義一個(gè)seq_test,最小值為10000,最大值為99999999999999999,從20000開(kāi)始,增量的步長(zhǎng)為1,緩存為20的循環(huán)排序Sequence。

 

Oracle的定義方法:

create sequence seq_test

minvalue 10000

maxvalue 99999999999999999

start with 20000

increment by 1

cache 20

cycle

order;

 

DB2的寫(xiě)法:

create sequence seq_test

      as bigint

      start with 20000

      increment by 1

      minvalue 10000

      maxvalue 99999999999999999

      cycle

      cache 20

      order;

 

PostgreSQL的寫(xiě)法:

create sequence seq_test

      increment by 1

      minvalue 10000

      maxvalue 99999999999999999

      start 20000

      cache 20

      cycle;

 

二、Oracle、DB2、PostgreSQL數(shù)據(jù)庫(kù)Sequence值的引用參數(shù)為:currval、nextval,分別表示當(dāng)前值和下一個(gè)值。下面分別從三個(gè)數(shù)據(jù)庫(kù)的Sequence中獲取nextval的值。

 

Oracle中:seq_test.nextval

例如:select seq_test.nextval from dual;

DB2中:nextval for SEQ_TOPICMS

例如:values nextval for seq_test;

PostgreSQL中:nextval(seq_test)

例如:select nextval(seq_test);

 

三、Sequence與indentity的區(qū)別與聯(lián)系

Sequence與indentity的基本作用都差不多。都可以生成自增數(shù)字序列。

Sequence是數(shù)據(jù)庫(kù)系統(tǒng)中的一個(gè)對(duì)象,可以在整個(gè)數(shù)據(jù)庫(kù)中使用,和表沒(méi)有任何關(guān)系;indentity僅僅是指定在表中某一列上,作用范圍就是這個(gè)表。