Oracle Sequence之深入淺出
Oracle有很多值得學(xué)習(xí)的地方,這里我們主要介紹Oracle Sequence,包括介紹Alter Sequence的例子等方面。第一次NEXTVAL返回的是初始值;隨后的NEXTVAL會(huì)自動(dòng)增加你定義的INCREMENT BY值,然后返回增加后的值。CURRVAL 總是返回當(dāng)前Sequence的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否則會(huì)出錯(cuò)。一次NEXTVAL會(huì)增加一次 Sequence的值,所以如果你在同一個(gè)語句里面使用多個(gè)NEXTVAL,其值就是不一樣的。明白?
如果指定CACHE值,Oracle就可以預(yù)先在內(nèi)存里面放置一些Sequence,這樣存取的快些。cache里面的取完后,Oracle自動(dòng)再取一組到cache。 使用cache或許會(huì)跳號(hào), 比如數(shù)據(jù)庫突然不正常down掉(shutdown abort),cache中的Sequence就會(huì)丟失. 所以可以在create Sequence的時(shí)候用nocache防止這種情況。
Alter Sequence
你或者是該Oracle Sequence的owner,或者有ALTER ANY Sequence 權(quán)限才能改動(dòng)Sequence. 可以alter除start至以外的所有Oracle Sequence參數(shù).如果想要改變start值,必須 drop Sequence 再 re-create.
Alter Sequence 的例子
- ALTER SEQUENCE emp_sequence
- INCREMENT BY 10
- MAXvalue 10000
- CYCLE -- 到10000后從頭開始
- NOCACHE ;
影響Oracle Sequence的初始化參數(shù):Sequence_CACHE_ENTRIES =設(shè)置能同時(shí)被cache的Sequence數(shù)目。
可以很簡單的Drop Sequence
- create sequence SEQ_ID
- minvalue 1
- maxvalue 99999999
- start with 1
- increment by 1
- nocache
- order;
建解發(fā)器代碼為:
- createorreplacetriggertri_test_id
- beforeinsertonS_Depart--S_Depart是表名
- foreachrow
- declare
- nextidnumber;
- begin
- IF:new.DepartIdISNULLor:new.DepartId=0THEN--DepartId是列名
- selectSEQ_ID.nextval--SEQ_ID正是剛才創(chuàng)建的
- intonextid
- fromsys.dual;
- :new.DepartId:=nextid;
- endif;
- endtri_test_id;
OK,上面的代碼就可以實(shí)現(xiàn)自動(dòng)遞增的功能了。
【編輯推薦】