程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> Oracle數據庫 >> Oracle數據庫基礎 >> Oracle Sequence之深入淺出

Oracle Sequence之深入淺出

編輯:Oracle數據庫基礎

Oracle有很多值得學習的地方,這裡我們主要介紹Oracle Sequence,包括介紹Alter Sequence的例子等方面。第一次NEXTVAL返回的是初始值;隨後的NEXTVAL會自動增加你定義的INCREMENT BY值,然後返回增加後的值。CURRVAL 總是返回當前Sequence的值,但是在第一次NEXTVAL初始化之後才能使用CURRVAL,否則會出錯。一次NEXTVAL會增加一次 Sequence的值,所以如果你在同一個語句裡面使用多個NEXTVAL,其值就是不一樣的。明白?

如果指定CACHE值,Oracle就可以預先在內存裡面放置一些Sequence,這樣存取的快些。cache裡面的取完後,Oracle自動再取一組到cache。 使用cache或許會跳號, 比如數據庫突然不正常down掉(shutdown abort),cache中的Sequence就會丟失. 所以可以在create Sequence的時候用nocache防止這種情況。

Alter Sequence

你或者是該Oracle Sequence的owner,或者有ALTER ANY Sequence 權限才能改動Sequence. 可以alter除start至以外的所有Oracle Sequence參數.如果想要改變start值,必須 drop Sequence 再 re-create.

Alter Sequence 的例子

  1. ALTER SEQUENCE emp_sequence  
  2. INCREMENT BY 10  
  3. MAXvalue 10000  
  4. CYCLE -- 到10000後從頭開始  
  5. NOCACHE ;  

影響Oracle Sequence的初始化參數:Sequence_CACHE_ENTRIES =設置能同時被cache的Sequence數目。

可以很簡單的Drop Sequence

  1. create sequence SEQ_ID  
  2. minvalue 1  
  3. maxvalue 99999999  
  4. start with 1  
  5. increment by 1  
  6. nocache  
  7. order; 

建解發器代碼為:

  1. createorreplacetriggertri_test_id  
  2. beforeinsertonS_Depart--S_Depart是表名  
  3. foreachrow  
  4. declare  
  5. nextidnumber;  
  6. begin  
  7. IF:new.DepartIdISNULLor:new.DepartId=0THEN--DepartId是列名  
  8. selectSEQ_ID.nextval--SEQ_ID正是剛才創建的  
  9. intonextid  
  10. fromsys.dual;  
  11. :new.DepartId:=nextid;  
  12. endif;  
  13. endtri_test_id; 

OK,上面的代碼就可以實現自動遞增的功能了。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved