SQL AUTO INCREMENT 字段
Auto-increment 會在新記錄插入表中時生成一個唯一的數(shù)字。
AUTO INCREMENT 字段
我們通常希望在每次插入新記錄時自動創(chuàng)建主鍵字段的值。
我們可以在表中創(chuàng)建一個自動增量(auto-increment)字段。
用于 MySQL 的語法
以下SQL語句將 "Persons" 表中的“ID”列定義為自動遞增(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關鍵字來執(zhí)行自動增量( auto-increment )任務。
默認情況下,AUTO_INCREMENT的起始值為1,每個新記錄增加1。
若要以其他值開始AUTO_INCREMENT序列,請使用以下SQL語法:
ALTER TABLE Persons AUTO_INCREMENT=100
要在 "Persons" 表中插入新記錄,我們不需要為"ID"欄指定值(自動添加唯一值):
INSERT INTO Persons (FirstName,LastName)
VALUES ('Lars','Monsen')
上面的SQL語句在 "Persons" 表中插入一個新記錄?!癐D”欄將得到唯一值。"FirstName"欄設置為"Lars","LastName"欄設置為"Monsen"。
用于 SQL Server 的語法
以下SQL語句將 "Persons" 表中的“ID”列定義為自動遞增( 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關鍵字執(zhí)行自動增量( auto-increment )任務。
在上面的示例中,IDENTITY的起始值為1,每個新記錄增量為1。
提示:指定“ID”列以10開頭,并遞增5,將標識( identity )更改為IDENTITY(10,5)。
要在 "Persons" 表中插入新記錄,我們不需要為"ID"欄指定值(自動添加唯一值):
INSERT INTO Persons (FirstName,LastName)
VALUES ('Lars','Monsen')
上面的 SQL 語句在 "Persons" 表中插入一個新記錄?!癐D”欄將得到唯一值。"FirstName"欄設置為"Lars","LastName"欄設置為"Monsen"。
用于 Access 的語法
以下 SQL 語句將 "Persons" 表中的“ID”列定義為自動遞增( 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 關鍵字執(zhí)行自動增量( auto-increment )任務。
默認情況下,AUTOINCREMENT的起始值為1,每個新記錄遞增 1。
提示:指定“ID”欄以10開頭,并遞增5,將自動遞增( autoincrement )更改為自動遞增(105)( AUTOINCREMENT(10,5))。
要在 "Persons" 表中插入新記錄,我們不需要為"ID"欄指定值(自動添加唯一值):
INSERT INTO Persons (FirstName,LastName)
VALUES ('Lars','Monsen')
上面的 SQL 語句在 "Persons" 表中插入一個新記錄?!癐D”欄將得到唯一值。"FirstName"欄設置為"Lars","LastName"欄設置為"Monsen"。
語法 for Oracle
在 Oracle 中,代碼有點復雜。
您必須使用序列( sequence )對象(該對象生成數(shù)字序列)創(chuàng)建自動增量( auto-increment )字段。
使用以下CREATSEQUENT語法:
CREATE SEQUENCE seq_person
MINVALUE 1
START WITH 1
INCREMENT BY 1
CACHE 10
上面的代碼創(chuàng)建了一個名為seq_pean的序列( sequence) 對象,它以1開頭,以1遞增。此對象緩存10個值以提高性能。緩存選項指定要存儲多少序列值以提高訪問速度。
要在"Persons" 表中插入新記錄,我們必須使用nextval函數(shù),該函數(shù)從seq_hor序列檢索下一個值:
INSERT INTO Persons (ID,FirstName,LastName)
VALUES (seq_person.nextval,'Lars','Monsen')
上面的SQL語句在 "Persons" 表中插入一個新記錄。"ID" 列從 seq_person 序列中分配下一個數(shù)字。"FirstName"欄設置為"Lars","LastName"欄設置為"Monsen"。
更多建議: