亚洲免费乱码视频,日韩 欧美 国产 动漫 一区,97在线观看免费视频播国产,中文字幕亚洲图片

      1. <legend id="ppnor"></legend>

      2. 
        
        <sup id="ppnor"><input id="ppnor"></input></sup>
        <s id="ppnor"></s>

        oracle中如何設(shè)置自增主鍵

        字號(hào):


            首先,你要有一張表!
            CREATE TABLE example(
            ID Number(4) NOT NULL PRIMARY KEY,
            NAME VARCHAR(25),
            PHONE VARCHAR(10),
            ADDRESS VARCHAR(50));
            如果對(duì)于以上的建表語(yǔ)句還有疑問(wèn)的話(huà),建議您不要繼續(xù)了!有那么些時(shí)間您還不如去看看金庸讀讀瓊瑤!
            然后,你需要一個(gè)自定義的sequence
            CREATE SEQUENCE emp_sequence
            INCREMENT BY 1 -- 每次加幾個(gè)
            START WITH 1 -- 從1開(kāi)始計(jì)數(shù)
            NOMAXVALUE -- 不設(shè)置最大值
            NOCYCLE -- 一直累加,不循環(huán)
            NOCACHE -- 不建緩沖區(qū)
            以上代碼完成了一個(gè)序列(sequence)的建立過(guò)程,名稱(chēng)為emp_sequence,范圍是從1開(kāi)始到無(wú)限大(無(wú)限大的程度是由你機(jī)器決定的),nocycle 是決定不循環(huán),如果你設(shè)置了最大值那么你可以用cycle 會(huì)使seq到最大之后循環(huán).對(duì)于nocache順便說(shuō)一下如果你給出了cache值那么系統(tǒng)將自動(dòng)讀取你的cache值大小個(gè)seq
            ,這樣在反復(fù)操作時(shí)會(huì)加快運(yùn)行速度,但如果遭遇意外情況如當(dāng)機(jī)了或oracle死了,則下次取出的seq值將和上次的不連貫.(如果連不連貫無(wú)所謂建議用cache,因?yàn)闀r(shí)間就是金錢(qián)呀!跑題了!)
            書(shū)接上文,你只有了表和序列還不夠,還需要一個(gè)觸發(fā)器來(lái)執(zhí)行它!代碼如下:
            CREATE TRIGGER "觸發(fā)器名稱(chēng)" 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的簡(jiǎn)單介紹(自增長(zhǎng)字段)- -
            在oracle中sequence就是所謂的序列號(hào),每次取的時(shí)候它會(huì)自動(dòng)增加,一般用在需要按序列號(hào)排序的地方。
            1、CreateSequence
            你首先要有CREATESEQUENCE或者CREATEANYSEQUENCE權(quán)限,
            CREATESEQUENCEemp_sequence
            INCREMENTBY1--每次加幾個(gè)
            STARTWITH1--從1開(kāi)始計(jì)數(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的地方:
            -不包含子查詢(xún)、snapshot、VIEW的SELECT語(yǔ)句
            -INSERT語(yǔ)句的子查詢(xún)中
            -NSERT語(yǔ)句的VALUES中
            -UPDATE的SET中
            可以看如下例子:
            INSERTINTOempVALUES
            (empseq.nextval,''LEWIS'',''CLERK'',7902,SYSDATE,1200,NULL,20);
            SELECTempseq.currvalFROMDUAL;
            但是要注意的是:
            -第一次NEXTVAL返回的是初始值;隨后的NEXTVAL會(huì)自動(dòng)增加你定義的INCREMENTBY值,然后返回增加后的值。CURRVAL總是返回當(dāng)前SEQUENCE的值,但是在第一次NEXTVAL初始化之后才能使用CURRVAL,否則會(huì)出錯(cuò)。一次NEXTVAL會(huì)增加一次SEQUENCE的值,所以如果你在同一個(gè)語(yǔ)句里面使用多個(gè)NEXTVAL,其值就是不一樣的。明白?
            -如果指定CACHE值,ORACLE就可以預(yù)先在內(nèi)存里面放置一些sequence,這樣存取的快些。cache里面的取完后,oracle自動(dòng)再取一組到cache。使用cache或許會(huì)跳號(hào),比如數(shù)據(jù)庫(kù)突然不正常down掉(shutdownabort),cache中的sequence就會(huì)丟失.所以可以在createsequence的時(shí)候用nocache防止這種情況。
            2、AlterSequence
            你或者是該sequence的owner,或者有ALTERANYSEQUENCE權(quán)限才能改動(dòng)sequence.可以alter除start至以外的所有sequence參數(shù).如果想要改變start值,必須dropsequence再re-create.
            Altersequence的例子
            ALTERSEQUENCEemp_sequence
            INCREMENTBY10
            MAXVALUE10000
            CYCLE--到10000后從頭開(kāi)始
            NOCACHE;
            影響Sequence的初始化參數(shù):
            SEQUENCE_CACHE_ENTRIES=設(shè)置能同時(shí)被cache的sequence數(shù)目。
            可以很簡(jiǎn)單的DropSequence
            DROPSEQUENCEorder_seq;
            好吧,就到這里。
            -------------------------------------------------------------
            自增長(zhǎng)及觸發(fā)器:
            如何在Oracle中實(shí)現(xiàn)類(lèi)似自動(dòng)增加ID的功能?
            整理編輯:ChinaASP
            我們經(jīng)常在設(shè)計(jì)數(shù)據(jù)庫(kù)的時(shí)候用一個(gè)系統(tǒng)自動(dòng)分配的ID來(lái)作為我們的主鍵,但是在ORACLE中沒(méi)有這樣的
            功能,我們可以通過(guò)采取以下的功能實(shí)現(xiàn)自動(dòng)增加ID的功能
            1.首先創(chuàng)建sequence
            createsequenceseqmaxincrementby1
            2.使用方法
            selectseqmax.nextvalIDfromdual
            就得到了一個(gè)ID
            如果把這個(gè)語(yǔ)句放在觸發(fā)器中,就可以實(shí)現(xiàn)和mssql的自動(dòng)增加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
            ###建自動(dòng)更新的觸發(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.