午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    oracle中如何設(shè)置自增主鍵
    來源:易賢網(wǎng) 閱讀:827 次 日期:2015-03-03 10:21:51
    溫馨提示:易賢網(wǎng)小編為您整理了“oracle中如何設(shè)置自增主鍵”,方便廣大網(wǎng)友查閱!

    首先,你要有一張表!

    CREATE TABLE example(

    ID Number(4) NOT NULL PRIMARY KEY,

    NAME VARCHAR(25),

    PHONE VARCHAR(10),

    ADDRESS VARCHAR(50));

    如果對于以上的建表語句還有疑問的話,建議您不要繼續(xù)了!有那么些時間您還不如去看看金庸讀讀瓊瑤!

    然后,你需要一個自定義的sequence

    CREATE SEQUENCE emp_sequence

    INCREMENT BY 1 -- 每次加幾個

    START WITH 1 -- 從1開始計數(shù)

    NOMAXVALUE -- 不設(shè)置最大值

    NOCYCLE -- 一直累加,不循環(huán)

    NOCACHE -- 不建緩沖區(qū)

    以上代碼完成了一個序列(sequence)的建立過程,名稱為emp_sequence,范圍是從1開始到無限大(無限大的程度是由你機器決定的),nocycle 是決定不循環(huán),如果你設(shè)置了最大值那么你可以用cycle 會使seq到最大之后循環(huán).對于nocache順便說一下如果你給出了cache值那么系統(tǒng)將自動讀取你的cache值大小個seq

    ,這樣在反復(fù)操作時會加快運行速度,但如果遭遇意外情況如當(dāng)機了或oracle死了,則下次取出的seq值將和上次的不連貫.(如果連不連貫無所謂建議用cache,因為時間就是金錢呀!跑題了!)

    書接上文,你只有了表和序列還不夠,還需要一個觸發(fā)器來執(zhí)行它!代碼如下:

    CREATE TRIGGER "觸發(fā)器名稱" BEFORE

    INSERT ON example FOR EACH ROW WHEN (new.id is null)

    begin

    select emp_sequence.nextval into: new.id from dual;

    end;

    打完收工!下面你就試試插入數(shù)據(jù)吧!

    INSERT INTO example(Name,phone,address) Values(''Cao'',''56498543'',''Heibei'');

    =============================================================

    ORACLE SEQUENCE的簡單介紹(自增長字段)- -

    在oracle中sequence就是所謂的序列號,每次取的時候它會自動增加,一般用在需要按序列號排序的地方。

    1、CreateSequence

    你首先要有CREATESEQUENCE或者CREATEANYSEQUENCE權(quán)限,

    CREATESEQUENCEemp_sequence

    INCREMENTBY1--每次加幾個

    STARTWITH1--從1開始計數(shù)

    NOMAXVALUE--不設(shè)置最大值

    NOCYCLE--一直累加,不循環(huán)

    CACHE10;

    一旦定義了emp_sequence,你就可以用CURRVAL,NEXTVAL

    CURRVAL=返回sequence的當(dāng)前值

    NEXTVAL=增加sequence的值,然后返回sequence值

    比如:

    emp_sequence.CURRVAL

    emp_sequence.NEXTVAL

    可以使用sequence的地方:

    -不包含子查詢、snapshot、VIEW的SELECT語句

    -INSERT語句的子查詢中

    -NSERT語句的VALUES中

    -UPDATE的SET中

    可以看如下例子:

    INSERTINTOempVALUES

    (empseq.nextval,''LEWIS'',''CLERK'',7902,SYSDATE,1200,NULL,20);

    SELECTempseq.currvalFROMDUAL;

    但是要注意的是:

    -第一次NEXTVAL返回的是初始值;隨后的NEXTVAL會自動增加你定義的INCREMENTBY值,然后返回增加后的值。CURRVAL總是返回當(dāng)前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否則會出錯。一次NEXTVAL會增加一次SEQUENCE的值,所以如果你在同一個語句里面使用多個NEXTVAL,其值就是不一樣的。明白?

    -如果指定CACHE值,ORACLE就可以預(yù)先在內(nèi)存里面放置一些sequence,這樣存取的快些。cache里面的取完后,oracle自動再取一組到cache。使用cache或許會跳號,比如數(shù)據(jù)庫突然不正常down掉(shutdownabort),cache中的sequence就會丟失.所以可以在createsequence的時候用nocache防止這種情況。

    2、AlterSequence

    你或者是該sequence的owner,或者有ALTERANYSEQUENCE權(quán)限才能改動sequence.可以alter除start至以外的所有sequence參數(shù).如果想要改變start值,必須dropsequence再re-create.

    Altersequence的例子

    ALTERSEQUENCEemp_sequence

    INCREMENTBY10

    MAXVALUE10000

    CYCLE--到10000后從頭開始

    NOCACHE;

    影響Sequence的初始化參數(shù):

    SEQUENCE_CACHE_ENTRIES=設(shè)置能同時被cache的sequence數(shù)目。

    可以很簡單的DropSequence

    DROPSEQUENCEorder_seq;

    好吧,就到這里。

    -------------------------------------------------------------

    自增長及觸發(fā)器:

    如何在Oracle中實現(xiàn)類似自動增加ID的功能?

    整理編輯:ChinaASP

    我們經(jīng)常在設(shè)計數(shù)據(jù)庫的時候用一個系統(tǒng)自動分配的ID來作為我們的主鍵,但是在ORACLE中沒有這樣的

    功能,我們可以通過采取以下的功能實現(xiàn)自動增加ID的功能

    1.首先創(chuàng)建sequence

    createsequenceseqmaxincrementby1

    2.使用方法

    selectseqmax.nextvalIDfromdual

    就得到了一個ID

    如果把這個語句放在觸發(fā)器中,就可以實現(xiàn)和mssql的自動增加ID相同的功能!

    -------------------------------------------------------------------------

    ###建表###

    CREATETABLE"SPORTS"."LINEUP"("ID"NUMBERNOTNULL,"TYPE"

    NUMBER(3)NOTNULL,"BODY"VARCHAR2(100)NOTNULL,"HITS"NUMBER(

    10)DEFAULT0NOTNULL,PRIMARYKEY("ID"))

    TABLESPACE"TS_SPORTS"

    ###建序列###

    CREATESEQUENCE"SPORTS"."SPORTS_LINEUP_ID_SEQ"INCREMENTBY1

    STARTWITH1MAXVALUE1.0E28MINVALUE1NOCYCLE

    CACHE50NOORDER

    ###建自動更新的觸發(fā)器###

    CREATEORREPLACETRIGGER"SPORTS"."SPORTS_LINEUP_ID_TRIGGER"

    BEFOREINSERT

    ON"SPORTS"."LINEUP"

    FOREACHROW

    DECLARE

    next_idNUMBER;

    BEGIN

    --Getthenextidnumberfromthesequence

    SELECTsports_lineup_id_seq.NEXTVAL

    INTOnext_id

    FROMdual;

    --Usethesequencenumberastheprimarykey

    --fortherecordbeinginserted.

    更多信息請查看IT技術(shù)專欄

    更多信息請查看數(shù)據(jù)庫
    易賢網(wǎng)手機網(wǎng)站地址:oracle中如何設(shè)置自增主鍵
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2025國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機號
    • 驗證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報警專用圖標(biāo)