成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle自增ID實(shí)現(xiàn)的具體操作步驟

數(shù)據(jù)庫 Oracle
以下的文章主要是對Oracle自增ID實(shí)現(xiàn)的實(shí)際操作步驟的描述,以下就是具體方案的描述,希望在你今后的學(xué)習(xí)中會有所幫助。

我們今天是要和大家一起討論的是Oracle自增ID實(shí)現(xiàn),我對這一問題存在不解之處,前兩天在相關(guān)網(wǎng)站看見的資料,覺得挺好,就拿出來供大家分享,希望會給你帶來一些幫助在此方面。

首先,你要有一張表!

 

  1. CREATE TABLE example(  
  2. ID Number(4) NOT NULL PRIMARY KEY,  
  3. NAME VARCHAR(25),  
  4. PHONE VARCHAR(10),  
  5. ADDRESS VARCHAR(50) );  

 

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

CREATE SEQUENCE emp_sequence

INCREMENT BY 1 -- 每次加幾個

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

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

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

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

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

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

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

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

 

  1. INSERT ON example FOR EACH ROW WHEN (new.id is null)  
  2. begin  
  3. select emp_sequence.nextval into: new.id from dual;  
  4. end;  

 

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

 

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

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

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

1、Create Sequence

你首先要有Create Sequence或者Create AnySequence權(quán)限,

 

  1. Create Sequence emp_sequence 

INCREMENT BY 1 --每次加幾個

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

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

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

CACHE10 ;

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

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

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

比如:

 

  1. emp_sequence.CURRVAL  
  2. emp_sequence.NEXTVAL  

 

可以使用sequence的地方:

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

-INSERT語句的子查詢中

-INSERT語句的VALUES中

-UPDATE的SET中

可以看如下例子:

 

  1. INSERT INTO emp VALUES  
  2. (empseq.nextval,'LEWIS','CLERK',7902,SYSDATE,1200,NULL,20);  
  3. SELECT empseq.currval FROM DUAL;  

 

但是要注意的是:

第一次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、Alter Sequence

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

Alter sequence的例子

 

  1. ALTER SEQUENCE emp_sequence  
  2. INCREMENT BY 10  
  3. MAXVALUE 10000  

 

CYCLE--到10000后從頭開始

NOCACHE;

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

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

可以很簡單的Drop Sequence

 

  1. DRO SEQUENCE order_seq; 

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

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

我們經(jīng)常在設(shè)計數(shù)據(jù)庫的時候用一個系統(tǒng)自動分配的ID來作為我們的主鍵,但是在ORACLE中沒有這樣的功能,我們可以通過采取以下的功能實(shí)現(xiàn)自動增加ID的功能

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

 

  1. create sequence seq maxincrement by 1 

2.使用方法

 

  1. select seqmax.nextval ID from dual 

就得到了一個ID

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

建表

 

  1. CREATE TABLE "SPORTS"."LINEUP"("ID" NUMBER NOT NULL,  
  2. "TYPE" NUMBER(3) NOT NULL,  
  3. "BODY" VARCHAR2(100) NOT NULL,  
  4. "HITS" NUMBER(10) DEFAULT 0 NOT NULL,  
  5. PRIMARYKEY("ID"))  
  6. TABLESPACE "TS_SPORTS"  

 

建序列

 

  1. CREATE SEQUENCE "SPORTS"."SPORTS_LINEUP_ID_SEQ" INCREMENT BY 1  
  2. START WITH 1 MAXVALUE 1.0E28 MINVALUE 1 NOCYCLE  
  3. CACHE 50 NOORDER  

 

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

 

  1. CREATE OR REPLACE TRIGGER "SPORTS"."SPORTS_LINEUP_ID_TRIGGER"  
  2. BEFORE INSERT ON "SPORTS"."LINEUP" FOR EACH ROW  
  3. DECLARE  
  4. next_id NUMBER;  
  5. BEGIN  
  6. --Get the next id number from the sequence  
  7. SELECT sports_lineup_id_seq.NEXTVAL INTO next_id FROM dual;  
  8. --Use the sequence number as the primarykey  
  9. --for there cord being inserted.  
  10. :new.id:=next_id;  
  11. END;  

 

建保護(hù)PRIMARYKEY的觸發(fā)器

 

  1. CREATE OR REPLACE TRIGGER "SPORTS"."LINEUP_ID_UPDATE_TRIGGER"  
  2. BEFORE UPDATE OF "ID" ON "SPORTS"."LINEUP" FOR EACHROW  
  3. BEGIN  
  4. RAISE_APPLICATION_ERROR(-20000,  
  5. 'sports_lineup_id_update_trigger:Update sof the ID field'  
  6. ||'arenotallowed.');  
  7. END;  

 

建刪除的觸發(fā)器

  1. create or replace trigger tr_bis_exc_req_del  
  2. before delete  
  3. on bis_exc_req  
  4. referencing old as old new as new  
  5. for each row  
  6. begin  
  7. if :old.check_status = '3' then  
  8. raise_application_error (-20001,'*****!');  
  9. return;  
  10. end if;  
  11. end;  
  12. /  

 

建更新的觸發(fā)器

  1. create or replace trigger tr_bis_exc_req_upd  
  2. before update  
  3. on bis_exc_req  
  4. referencing old as old new as new  
  5. for each row  
  6. begin  
  7. if :old.check_status = '3' then  
  8. raise_application_error (-20001,'*******!');  
  9. return;  
  10. end if;  
  11. end;   

 

責(zé)任編輯:佚名 來源: 博客園
相關(guān)推薦

2010-04-01 17:25:46

Oracle死鎖進(jìn)程

2010-03-30 09:37:01

Oracle導(dǎo)出工具

2010-04-02 08:42:32

Oracle 游標(biāo)

2010-02-24 13:06:27

WCF使用Nhiber

2010-03-02 09:39:11

保護(hù)WCF服務(wù)

2010-04-26 14:03:02

Oracle使用

2010-03-29 14:09:12

Oracle ID 自

2010-03-01 14:56:48

WCF服務(wù)引用

2010-08-03 09:25:02

DB2數(shù)據(jù)庫離線

2010-03-25 17:39:37

Python web

2009-11-23 16:43:03

PHP5安裝GD庫

2010-04-13 17:00:27

Oracle NLS_

2010-07-26 13:30:23

2010-08-02 17:20:12

nfs啟動Linux

2010-08-02 12:34:09

ADSL代理設(shè)置

2010-08-09 09:31:54

DB2 HADRv8.

2010-06-18 11:31:48

SQL Server數(shù)

2009-12-30 15:47:40

Silverlight

2011-03-17 09:06:58

iptables映射端口

2010-07-15 19:46:40

關(guān)閉Telnet 23
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 黄色一级大片在线免费看产 | 日本网站免费观看 | 香蕉婷婷 | 欧美日韩成人 | 国产精品人人做人人爽 | 久久精品国产99国产精品 | 日本成人中文字幕 | 欧美一区二区黄 | 一区二区视频在线 | 国产精品久久久久久久久久免费 | 精品国产乱码久久久久久88av | 久久久久se | 国产在线一区二区三区 | 亚洲精品成人 | 午夜精品一区二区三区在线观看 | 久草中文在线 | 天天草天天射 | 国产精品免费在线 | 国产精品 欧美精品 | 精品欧美一区免费观看α√ | 91精品欧美久久久久久久 | 日本视频一区二区 | 日韩一区二区三区四区五区六区 | 国产综合视频 | 一区二区在线免费观看 | 一区二区三区亚洲精品国 | 国产精品a免费一区久久电影 | 久久国产精品网站 | 亚洲第一av | 亚洲免费片 | 亚洲性爰| 久久久久久久91 | 成人在线视频观看 | av天天看 | 日韩一区在线视频 | 亚洲福利在线视频 | 九色国产 | 国产成人99久久亚洲综合精品 | 中文字幕在线观看视频一区 | yiren22综合网成人 | 国产精品久久久久久 |