面試突擊:一個表中可以有多個自增列嗎?
作者 | 磊哥
來源 | Java面試真題解析(ID:aimianshi666)
轉(zhuǎn)載請聯(lián)系授權(quán)(微信ID:GG_Stone)
自增列可使用 auto_increment 來實現(xiàn),當(dāng)一個列被標(biāo)識為 auto_increment 之后,在添加時如果不給此列設(shè)置任何值,或給此列設(shè)置 NULL 值時,那么它會使用自增的規(guī)則來填充此列。
PS:本文以下內(nèi)容基于 MySQL InnoDB 數(shù)據(jù)庫引擎。
默認情況下自增列的值為 1,每次遞增 1,比如以下建表 SQL:
create table tab_incre(
id int primary key auto_increment,
name varchar(250) not null
);
我們在添加時,不給自增列 id 設(shè)置任何值,它的執(zhí)行結(jié)果如下:
從上述結(jié)果可以看出自增列默認值為 1,每次遞增 1。
1、手動指定自增值
在創(chuàng)建表的時候可以手動指定自增值,如果不指定自增值,那么它默認會使用 1 作為自增值,手動指定自增值的 SQL 命令如下:
create table tab_incre(
id int primary key auto_increment,
name varchar(250) not null
) auto_increment=50;
使用“show create table table_name”可以查看表中自增列的自增列值,如下圖所示:
此表的自增值為 50,我們也可以創(chuàng)建一條數(shù)據(jù)來驗證一下自增值是否為 50,如下圖所示:
2、手動修改自增值
當(dāng)表創(chuàng)建之后,我們也可以通過 alter 命令來修改自增列的值,它的修改命令如下:
alter table table_name auto_increment=n;
如果要將 tab_incre 表中的自增值修改為 100,可使用以下 SQL 來實現(xiàn):
注意事項
當(dāng)我們試圖將自增值設(shè)置為比自增列中的最大值還要小的值的時候,自增值會自動變?yōu)樽栽隽械淖畲笾?+1 的值,如下圖所示:
3、一個表可以有多個自增列嗎?
一個表中只能有一個自增列,這和一個表只能有一個主鍵的規(guī)則類似,當(dāng)我們嘗試給一個表添加一個自增列時,可以正常添加成功,如下圖所示:
當(dāng)我們嘗試給一個表添加多個自增列時,會提示只能有一個自增列的報錯信息,如下圖所示:
4、其他注意事項
除了一個表只能添加一個自增列之外,自增列還需要注意以下兩個問題。
(1)自增列只能為整數(shù)類型
自增列的字段類型只能為整數(shù)類型(TINYINT、SMALLINT、INT、BIGINT 等),如下圖所示:
當(dāng)我們使用其他類型來作為自增列的數(shù)據(jù)類型時,會提示如下錯誤:
(2)必須配合 key 一起使用
auto_increment 必須配合 key 一起使用,這個 key 可以是 primary key 或 foreign key,如果沒有 key 就會報錯,如下所示:
PS:auto_increment 也可以配合唯一約束 unique 一起使用。
總結(jié)
自增列的值默認是 1,每次遞增 1,但也可以在創(chuàng)建表的時候手動指定自增值,當(dāng)然在特殊情況下我們在表被創(chuàng)建之后,也可以通過 alter 修改自增值。一個表中只能有一個自增列,就像一個表中只能有一個主鍵一樣,如果設(shè)置多個自增列,那么 SQL 執(zhí)行就會報錯。除此之外還要注意自增列應(yīng)該為整數(shù)類型,且 auto_increment 需要配合 key 一起使用,這個 key 可以是 primary key 或 foreign key。