相關(guān)的 Oracle Database Sequence 資訊如下:
建立 Sequence 語法
create sequence <schema>.<table_name>_s
increment by 1
start with 1
maxvalue 99999999999999999999
minvalue 1-
nocycle;
其中 :
incerment: 每次增加的數(shù)值
start : Sequence 開始數(shù)值
maxvalue : Sequence 最大值
nocycle : 當(dāng) Sequence 達(dá)最大值時,不重頭開始
取得下一筆 Sequence 值
select <Sequence_name>.nextval[@db_link]
from dual;
查詢目前 Sequence 值
語法 1:
select <Sequence_name>.currval[@db_link]
from dual;
Mark 提供: 若 "目前所在的 DB Session" 尚未執(zhí)行 nextval, 就先執(zhí)行 currval, 則會得到
ORA-08002: sequence DB_SESSION_ID.CURRVAL is not yet defined in this session 錯誤.
語法 2:
select last_number - 1
from all_sequences
where sequence_name = '<Sequence_name>';
修改 Sequence
如: Alter Sequence <Sequence_name> MaxValue 999999999999999;
注意事項
1) Sequence 不能直接用在 "等式 :=" 之后.如: vID := tomSeq.nextval;
2) Sequence 可以直接用在 "SQL" 之中.如: insert into tomTable values( tomSeq.nextval, ... ); 本文出自:億恩科技【mszdt.com】
服務(wù)器租用/服務(wù)器托管中國五強(qiáng)!虛擬主機(jī)域名注冊頂級提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM]
|