1. 程式人生 > >資料庫sequence的作用和用法

資料庫sequence的作用和用法

seqence的作用:

sequence號是資料庫系統按照一定規則自增的數字序列,因為自增所以不會重複。目前就我所瞭解的sequence的作用主要有兩個方面。

一:作為代理主鍵,唯一識別;

二:用於記錄資料庫中最新動作的語句,只要語句有動作(I/U/D等),sequence號都會隨著更新,所以我們可以根據sequence號來select出更新的語句。

sequence的用法:

sequence和創表類似,需要建立一個sequence,然後表的一個int型欄位可以使用這個sequence。

建立一個sequence(db2,oracle均適用)

create seqence sequence_name 

[start with n1] 

[increment by n2] 

[maxvalue n3|no maxvalue] 

[minvalue n4|no minvalue] 

[cache n5|no cache] 

[cycle|no cycle] 

[order|no order]

----------------->n1到n5都是整數

----------------->start with 生成的第一個n1值

-----------------> increment by n2 遞增量,可以為正整數或負整數,指明每一次增加多少

----------------->maxvalue最大值,no maxvalue用於指定序列沒有上限

----------------->minvalue 最小值,no minvalue,沒有指定最小下限

----------------->cache 用快取記憶體中可以預分配的序列號個數,預設是20。 如果快取中的序列號沒有用完就關閉資料庫等其它原因. 沒有使用的序列號就丟失了,所以不能保證序列號是連續的。nocache高速緩衝中不預分配序列號,每次只生成一個序列號,雖然降低了獲取序列號的速度,但是可以保證序列號的連續性。

----------------->cycle 序列達到最大值或最小值後是否迴圈。再從n1開始迴圈,預設不no cycle

----------------->order用於指定按順序生成序列,只有在RAC時需要指定,指定ORDER 是為了保證序列號是因為有請求才生成的。在使用序列號做為一個時間戳時很有用,

no order是不指定按順序生成序列(預設)。

建立一個sequence:

create sequence sequence_name as int minvalue 1000 maxvalue 1000000000 start with 1000 increment by 1 no cache;

或者

create sequence sequence_name minvalue 1000 no maxvalue start with 1000 increment by 1 no cache;

sequence的使用:

sequence_name.nextval------->引用下一個序列值

sequence_name.currval/seqence_name.nextval.currval-------->引用當前序列值,必須最少經過一個nextval才能引用currval

在表中使用sequence:

create table tab_name(col_int int, col_varchar varchar(20), col_seq int);

insert tab_name into values(1, 'abc', nextval for sequence_name);   或者 insert tab_name into values(1, 'xyz', sequence_name.nextval);

insert tab_name into values(2, 'fgh', nextval for sequence_name);   或者 insert tab_name into values(2, 'fgh', sequence_name.nextval);

update tab_name set col_varchar='678', col_seq=sequence_name.nextval where col_int=2; 

delete tab_name col_sql=sequence_name.nextval where col_int=1;

單獨使用查詢sequence:

select sequence_name.nextval from dual;------>每執行一次sequence號會一直增加

select sequence_name.currval from dual;------->執行多少次都不會變化

改變sequence:

比如對以上建立的sequence除了初始值以外的值進行修改,alter sequence_name minvalue 100000 maxvalue 99999999 increment by 10 cache 10 cycle;

刪除sequence:

drop sequence sequence_name;

利用解發器自動為表插入遞增序列:---類似自增欄位的作用

建解發器程式碼為:
create or replace trigger trigger_id
before insert on tabname
for each row
declare
nextid number;
begin
IF :new.col_seq IS NULL or :new.col_seq=0 THEN
select sequence_name.nextval
into nextid from sys.dual;
:new.col_seq:=nextid;
end IF;
end trigger_id;

或者

create trigger trigger_id before
insert on tabname
for each row

begin
select sequence_name.nextval 
into:new.col_seq 
from dual;
end trigger_id;

或者

create or replace trigger trigger_id
before insert or update of col_seq
on tabname
for each row
begin
if inserting then
select sequen_name.nextval into:new.col_seq from dual;
slse
raise_application_error(-20020, '不允許更新ID值!');
end if;
end;