oracle sql序列,SQL server 和Oracle 序列
1,SQL Server序列創(chuàng)建與使用
BEGIN
IF EXISTS (SELECT * FROM sysobjects WHERE name = 'event_seq')
DROP SEQUENCE event_seq
END
CREATE SEQUENCE event_seq
MINVALUE 1
MAXVALUE 999999999999999999
START WITH 1
INCREMENT BY 1
CACHE 20;
--使用時
GO
select next value for event_seq;
GO
INSERT INTO NAMETABLE (INDEX,NAME) VALUES (2,'S_CN' + rtrim(ltrim(right(cast('00000000'+rtrim(next value for ENTITY_SEQ) as varchar(20)),10))))
--查詢下個序列值
SELECT
NEXT VALUE FOR [dbo].[ATTENDANCE_SEQ];
--查詢當(dāng)前序列值
SELECT cache_size, current_value
FROM sys.sequences
WHERE name = 'ATTENDANCE_SEQ'
2 Oracle序列創(chuàng)建與使用
BEGIN
EXECUTE IMMEDIATE 'DROP SEQUENCE STAFF_SEQ';
EXCEPTION WHEN OTHERS THEN NULL;
END;
CREATE SEQUENCE STAFF_SEQ
MINVALUE 1
MAXVALUE 999999999999999999999999999
START WITH 1
INCREMENT BY 1
CACHE 20;
--在觸發(fā)器中使用序列
CREATE OR REPLACE TRIGGER TR_INST_STAFF
BEFORE INSERT ON M_MAINTENANCESTAFF
FOR EACH ROW
BEGIN
select STAFF_SEQ.NEXTVAL into :new.STAFFINDEX from dual;
END;
--STAFF_SEQ.NEXTVAL標(biāo)示下一個序列值
--STAFF_SEQ.CURRVAL標(biāo)示下一個序列值
序列關(guān)鍵字:
1)INCREMENT BY用于定義序列的步長,如果省略,則默認(rèn)為1,如果出現(xiàn)負(fù)值,則代表Oracle序列的值是按照此步長遞減的。
2)START WITH 定義序列的初始值(即產(chǎn)生的第一個值),默認(rèn)為1。
3)MAXVALUE 定義序列生成器能產(chǎn)生的最大值。選項(xiàng)NOMAXVALUE是默認(rèn)選項(xiàng),代表沒有最大值定義,這時對于遞增Oracle序列,系統(tǒng)能夠產(chǎn)生的最大值是10的27次方;對于遞減序列,最大值是-1。
4)MINVALUE定義序列生成器能產(chǎn)生的最小值。選項(xiàng)NOMAXVALUE是默認(rèn)選項(xiàng),代表沒有最小值定義,這時對于遞減序列,系統(tǒng)能夠產(chǎn)生的最小值是?10的26次方;對于遞增序列,最小值是1。
5)CYCLE和NOCYCLE 表示當(dāng)序列生成器的值達(dá)到限制值后是否循環(huán)。CYCLE代表循環(huán),NOCYCLE代表不循環(huán)。如果循環(huán),則當(dāng)遞增序列達(dá)到最大值時,循環(huán)到最小值;對于遞減序列達(dá)到最小值時,循環(huán)到最大值。如果不循環(huán),達(dá)到限制值后,繼續(xù)產(chǎn)生新值就會發(fā)生錯誤。
6)CACHE(緩沖)定義存放序列的內(nèi)存塊的大小,默認(rèn)為20。NOCACHE表示不對序列進(jìn)行內(nèi)存緩沖。對序列進(jìn)行內(nèi)存緩沖,可以改善序列的性能。
總結(jié)
以上是生活随笔為你收集整理的oracle sql序列,SQL server 和Oracle 序列的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: oracle输出xml文件格式,在ora
- 下一篇: 什么是长期存储在计算机外存上的有结构,数