面試突擊59:一個表中可以有多個自增列嗎?
自增列可使用 auto_increment 來實現,當一個列被標識為 auto_increment 之後,在新增時如果不給此列設定任何值,或給此列設定 NULL 值時,那麼它會使用自增的規則來填充此列。
PS:本文以下內容基於 MySQL InnoDB 資料庫引擎。
預設情況下自增列的值為 1,每次遞增 1,比如以下建表 SQL:
create table tab_incre( id int primary key auto_increment, name varchar(250) not null );
我們在新增時,不給自增列 id 設定任何值,它的執行結果如下:
從上述結果可以看出自增列預設值為 1,每次遞增 1。
1.手動指定自增值
在建立表的時候可以手動指定自增值,如果不指定自增值,那麼它預設會使用 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,我們也可以建立一條資料來驗證一下自增值是否為 50,如下圖所示:
2.手動修改自增值
當表建立之後,我們也可以通過 alter 命令來修改自增列的值,它的修改命令如下:
alter table table_name auto_increment=n;
如果要將 tab_incre 表中的自增值修改為 100,可使用以下 SQL 來實現:
注意事項
當我們試圖將自增值設定為比自增列中的最大值還要小的值的時候,自增值會自動變為自增列的最大值 +1 的值,如下圖所示:
3.一個表可以有多個自增列嗎?
一個表中只能有一個自增列,這和一個表只能有一個主鍵的規則類似,當我們嘗試給一個表新增一個自增列時,可以正常新增成功,如下圖所示:
當我們嘗試給一個表新增多個自增列時,會提示只能有一個自增列的報錯資訊,如下圖所示:4.其他注意事項
除了一個表只能新增一個自增列之外,自增列還需要注意以下兩個問題。
4.1 自增列只能為整數型別
自增列的欄位型別只能為整數型別(TINYINT、SMALLINT、INT、BIGINT 等),如下圖所示:
當我們使用其他型別來作為自增列的資料型別時,會提示如下錯誤:
4.2 必須配合 key 一起使用
auto_increment 必須配合 key 一起使用,這個 key 可以是 primary key 或 foreign key,如果沒有 key 就會報錯,如下所示:
PS:auto_increment 也可以配合唯一約束 unique 一起使用。
總結
自增列的值預設是 1,每次遞增 1,但也可以在建立表的時候手動指定自增值,當然在特殊情況下我們在表被建立之後,也可以通過 alter 修改自增值。 一個表中只能有一個自增列 ,就像一個表中只能有一個主鍵一樣,如果設定多個自增列,那麼 SQL 執行就會報錯。除此之外還要注意自增列應該為整數型別,且 auto_increment 需要配合 key 一起使用,這個 key 可以是 primary key 或 foreign key。
是非審之於己,譭譽聽之於人,得失安之於數。
公眾號:Java面試真題解析
- Webpack學習系列 | Webpack 5 整合 HTML 外掛高效解決檔案路徑問題
- 程式設計師如何利用技術能力變現
- Unity3D學習筆記8——GPU例項化(3)
- 分散式事務(Seata)原理 詳解篇,建議收藏
- Spring 核心概念
- github package的使用教程
- ReentrantLock 公平鎖原始碼 第2篇
- 庖丁解牛斐波拉契數列和揹包問題——詳細解析兩個問題優化過程,帶你從最基本的問題看懂動態規劃!!!
- 0016:單源最短路徑(dijkstra演算法)
- Elasticsearch深度應用(下)
- Properties集合中的方法store和Properties集合中的方法load
- 寫出個靈活的系統竟然可以如此簡單!小白也能寫出高階的Java業務!
- 【docker專欄1】docker解決的實際問題及應用場景
- Linux系列之文字操作命令
- JAVA中簡單的for迴圈竟有這麼多坑,你踩過嗎
- Spring框架系列(13) - SpringMVC實現原理之DispatcherServlet的初始化過程
- Kafka KRaft模式探索
- Spring框架系列(3) - 深入淺出Spring核心之控制反轉(IOC)
- 面試突擊59:一個表中可以有多個自增列嗎?
- 前端學習 linux —— 第一篇