溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Oracle中的sequence如何使用

發(fā)布時間:2023-03-13 13:59:36 來源:億速云 閱讀:131 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“Oracle中的sequence如何使用”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

sequence是Oracle中的序列,可以實現(xiàn)字段的自增或自減效果

Oracle與MySQL、SQL server不同,沒有直接實現(xiàn)字段自增的功能,需要我們使用自增序列去實現(xiàn)

如:

--設(shè)置自增序列,名稱為"seq_userinfo",名字任意命名
create sequence seq_userinfo
 increment by 1		--每次+1	
 start with 1		--從1開始
 nomaxvalue			--不限最大值
 nominvalue			--不限最小值
 cache 20;			--設(shè)置取值緩存數(shù)為20

1、create sequence seq_userinfo

sequence :為關(guān)鍵字,表示"序列"

seq_userinfo:為序列的名稱,我們可以任意命名(注意符合命名規(guī)范即可)

2、increment  by  1

increment  :表示自增

by 1:表示每次變動1個整數(shù)單位

3、start with 1

表示從1開始

start with 200 :表示從200開始自增

4、nomaxvalue

表示不限制最大值,我們也可以手動設(shè)置最大值,如:

maxvalue  99999999999   --最大值為99999999999   

5、nominvallue

表示不限制最小值

6、cache  20

這個值特別重要

Oracle默認(rèn)cache=20

cache的作用:當(dāng)設(shè)置cache=20,第一次新增時,會往Oracle服務(wù)器的緩存中,存儲20個整數(shù)值,例如,我們第一次新增是從1開始,就會把1到20這個20個數(shù)字存儲到Oracle緩存中,當(dāng)下一次新增時,直接從緩存中獲取數(shù)字。

優(yōu)點:提高了insert時的效率,這里的cache效果與Java中的連接池效果是一致的!

缺點:Oracle服務(wù)器會存在不確定因素,從而導(dǎo)致緩存被刷新,從而導(dǎo)致cache還沒使用完,cache就失效了,不能保證自增序列的連續(xù)性。

說白了就是:緩存中存儲1到20個數(shù)字,用到10的時候,這一次的cache就被刷新失效了,下一次再新增時,會重新設(shè)置緩存(從21開始,再拿20個數(shù)字),從而導(dǎo)致自增的序列出現(xiàn)數(shù)字不連續(xù)的情況。在后端系統(tǒng)中,一般是不需要保證自增序列的連續(xù)性的,因此,設(shè)置cache值是必要的。

“Oracle中的sequence如何使用”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI