SQL AUTO INCREMENT 字段


 Auto-increment 會(huì)在新記錄插入表中時(shí)生成一個(gè)唯一的數(shù)字。


AUTO INCREMENT 字段


 我們通常希望在每次插入新記錄時(shí)自動(dòng)創(chuàng)建主鍵字段的值。

 我們可以在表中創(chuàng)建一個(gè)自動(dòng)增量(auto-increment)字段。


用于 MySQL 的語(yǔ)法


 以下SQL語(yǔ)句將 "Persons" 表中的“ID”列定義為自動(dòng)遞增(auto-increment)主鍵字段:

CREATE TABLE Persons                
(                
ID int NOT NULL AUTO_INCREMENT,                
LastName varchar(255) NOT NULL,                
FirstName varchar(255),                
Address varchar(255),                
City varchar(255),                
PRIMARY KEY (ID)                
)

 MySQL使用AUTO_INCREMENT關(guān)鍵字來(lái)執(zhí)行自動(dòng)增量( auto-increment )任務(wù)。 

 默認(rèn)情況下,AUTO_INCREMENT的起始值為1,每個(gè)新記錄增加1。

 若要以其他值開(kāi)始AUTO_INCREMENT序列,請(qǐng)使用以下SQL語(yǔ)法:

ALTER TABLE Persons AUTO_INCREMENT=100       

 要在 "Persons" 表中插入新記錄,我們不需要為"ID"欄指定值(自動(dòng)添加唯一值):

INSERT INTO Persons (FirstName,LastName)                
VALUES ('Lars','Monsen')        

 上面的SQL語(yǔ)句在 "Persons" 表中插入一個(gè)新記錄?!癐D”欄將得到唯一值。"FirstName"欄設(shè)置為"Lars","LastName"欄設(shè)置為"Monsen"。


用于 SQL Server 的語(yǔ)法


 以下SQL語(yǔ)句將 "Persons" 表中的“ID”列定義為自動(dòng)遞增( auto-increment )主鍵字段:

CREATE TABLE Persons                
(                
ID int IDENTITY(1,1) PRIMARY KEY,                
LastName varchar(255) NOT NULL,                
FirstName varchar(255),                
Address varchar(255),                
City varchar(255)                
)       

 MS SQL Server使用IDENTITY關(guān)鍵字執(zhí)行自動(dòng)增量( auto-increment )任務(wù)。

 在上面的示例中,IDENTITY的起始值為1,每個(gè)新記錄增量為1。

 提示:指定“ID”列以10開(kāi)頭,并遞增5,將標(biāo)識(shí)( identity )更改為IDENTITY(10,5)。

 要在 "Persons" 表中插入新記錄,我們不需要為"ID"欄指定值(自動(dòng)添加唯一值):

INSERT INTO Persons (FirstName,LastName)                
VALUES ('Lars','Monsen')        

 上面的 SQL 語(yǔ)句在 "Persons" 表中插入一個(gè)新記錄。“ID”欄將得到唯一值。"FirstName"欄設(shè)置為"Lars","LastName"欄設(shè)置為"Monsen"。


用于 Access 的語(yǔ)法


 以下 SQL 語(yǔ)句將 "Persons" 表中的“ID”列定義為自動(dòng)遞增( auto-increment )主鍵字段:

CREATE TABLE Persons                
(                
ID Integer PRIMARY KEY AUTOINCREMENT,                
LastName varchar(255) NOT NULL,                
FirstName varchar(255),                
Address varchar(255),                
City varchar(255)                
)       

 MS Access使用 AUTOINCREMENT 關(guān)鍵字執(zhí)行自動(dòng)增量( auto-increment )任務(wù)。

 默認(rèn)情況下,AUTOINCREMENT的起始值為1,每個(gè)新記錄遞增 1。

 提示:指定“ID”欄以10開(kāi)頭,并遞增5,將自動(dòng)遞增( autoincrement )更改為自動(dòng)遞增(105)( AUTOINCREMENT(10,5))。

 要在 "Persons" 表中插入新記錄,我們不需要為"ID"欄指定值(自動(dòng)添加唯一值):

INSERT INTO Persons (FirstName,LastName)                
VALUES ('Lars','Monsen')        

 上面的 SQL 語(yǔ)句在 "Persons" 表中插入一個(gè)新記錄?!癐D”欄將得到唯一值。"FirstName"欄設(shè)置為"Lars","LastName"欄設(shè)置為"Monsen"。


語(yǔ)法 for Oracle


 在 Oracle 中,代碼有點(diǎn)復(fù)雜。

 您必須使用序列( sequence )對(duì)象(該對(duì)象生成數(shù)字序列)創(chuàng)建自動(dòng)增量( auto-increment )字段。

 使用以下CREATSEQUENT語(yǔ)法:

CREATE SEQUENCE seq_person                
MINVALUE 1                
START WITH 1                
INCREMENT BY 1                
CACHE 10        

 上面的代碼創(chuàng)建了一個(gè)名為seq_pean的序列( sequence) 對(duì)象,它以1開(kāi)頭,以1遞增。此對(duì)象緩存10個(gè)值以提高性能。緩存選項(xiàng)指定要存儲(chǔ)多少序列值以提高訪問(wèn)速度。

 要在"Persons" 表中插入新記錄,我們必須使用nextval函數(shù),該函數(shù)從seq_hor序列檢索下一個(gè)值:

INSERT INTO Persons (ID,FirstName,LastName)                
VALUES (seq_person.nextval,'Lars','Monsen')       

 上面的SQL語(yǔ)句在 "Persons" 表中插入一個(gè)新記錄。"ID" 列從 seq_person 序列中分配下一個(gè)數(shù)字。"FirstName"欄設(shè)置為"Lars","LastName"欄設(shè)置為"Monsen"。