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

面試突擊:一個表中可以有多個自增列嗎?

數據庫 MySQL
自增列的值默認是 1,每次遞增 1,但也可以在創建表的時候手動指定自增值,當然在特殊情況下我們在表被創建之后,也可以通過 alter 修改自增值。

作者 | 磊哥

來源 | Java面試真題解析(ID:aimianshi666)

轉載請聯系授權(微信ID:GG_Stone)

自增列可使用 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、其他注意事項

除了一個表只能添加一個自增列之外,自增列還需要注意以下兩個問題。

(1)自增列只能為整數類型

自增列的字段類型只能為整數類型(TINYINT、SMALLINT、INT、BIGINT 等),如下圖所示:

圖片

圖片當我們使用其他類型來作為自增列的數據類型時,會提示如下錯誤:

圖片圖片

(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面試真題解析
相關推薦

2010-11-11 12:06:39

SQL自增列

2020-03-09 09:07:51

Vue根節點Fragments

2022-04-11 07:40:45

synchroniz靜態方法程序

2022-07-11 07:10:48

HTTP協議類型

2010-11-03 15:56:13

DB2創建表

2022-05-05 07:38:32

volatilJava并發

2022-06-06 07:35:26

MySQLInnoDBMyISAM

2022-04-20 07:47:00

notify喚醒線程JVM

2022-07-27 07:36:01

TCP可靠性

2022-05-23 07:35:15

單例模式懶漢模式靜態內部類

2022-09-19 06:16:23

事務隔離級別Spring

2022-04-18 07:36:37

TimeUnit線程休眠

2022-05-11 07:41:55

死鎖運算線程

2022-08-22 07:06:32

MyBatisSQL占位符

2022-07-06 07:35:19

group byMySQL

2022-08-03 07:04:56

GETHTTPPOST

2022-04-26 08:02:00

locktryLocklockInterr

2022-08-10 07:06:57

IoCDISpring

2022-04-24 07:59:53

synchronizJVMAPI

2022-02-08 07:02:32

進程線程操作系統
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成年免费大片黄在线观看一级 | 精品1区 | 精品国产乱码久久久久久影片 | 国产精品国产三级国产aⅴ中文 | 范冰冰一级做a爰片久久毛片 | 日韩一区二区久久 | 综合久久av | 国产精品国色综合久久 | 在线免费国产 | 国产精品久久久久久久免费观看 | 欧美在线视频网 | 午夜影院操 | 午夜精品久久 | 激情影院久久 | 精品日韩| 午夜精品久久久久久久久久久久 | 久久性 | 成人免费福利 | 久久久综合精品 | 国产亚洲精品综合一区 | 日韩欧美精品在线 | 久久91精品 | 成人午夜看片 | 美女黄色在线观看 | 国产小视频在线 | 国产一区二区三区免费 | 91色站| 国产免费观看一区 | 国产高清精品一区二区三区 | 免费看a | 91视频久久 | 精品自拍视频在线观看 | 久久久久久久久久一区二区 | 激情自拍偷拍 | 午夜私人影院在线观看 | 久久69精品久久久久久久电影好 | 久久久精 | 久久99精品久久久久久国产越南 | 深夜福利亚洲 | 国产精品欧美一区二区三区不卡 | 操视频网站 |