偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

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

數(shù)據(jù)庫(kù) MySQL
自增列的值默認(rèn)是 1,每次遞增 1,但也可以在創(chuàng)建表的時(shí)候手動(dòng)指定自增值,當(dāng)然在特殊情況下我們?cè)诒肀粍?chuàng)建之后,也可以通過 alter 修改自增值。

作者 | 磊哥

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

轉(zhuǎn)載請(qǐng)聯(lián)系授權(quán)(微信ID:GG_Stone)

自增列可使用 auto_increment 來實(shí)現(xiàn),當(dāng)一個(gè)列被標(biāo)識(shí)為 auto_increment 之后,在添加時(shí)如果不給此列設(shè)置任何值,或給此列設(shè)置 NULL 值時(shí),那么它會(huì)使用自增的規(guī)則來填充此列。

PS:本文以下內(nèi)容基于 MySQL InnoDB 數(shù)據(jù)庫(kù)引擎。

默認(rèn)情況下自增列的值為 1,每次遞增 1,比如以下建表 SQL:

create table tab_incre(
id int primary key auto_increment,
name varchar(250) not null
);

圖片

我們?cè)谔砑訒r(shí),不給自增列 id 設(shè)置任何值,它的執(zhí)行結(jié)果如下:

圖片

圖片從上述結(jié)果可以看出自增列默認(rèn)值為 1,每次遞增 1。

1、手動(dòng)指定自增值

在創(chuàng)建表的時(shí)候可以手動(dòng)指定自增值,如果不指定自增值,那么它默認(rèn)會(huì)使用 1 作為自增值,手動(dòng)指定自增值的 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ù)來驗(yàn)證一下自增值是否為 50,如下圖所示:圖片

圖片

2、手動(dòng)修改自增值

當(dāng)表創(chuàng)建之后,我們也可以通過 alter 命令來修改自增列的值,它的修改命令如下:

alter table table_name auto_increment=n;

如果要將 tab_incre 表中的自增值修改為 100,可使用以下 SQL 來實(shí)現(xiàn):

圖片

注意事項(xiàng)

當(dāng)我們?cè)噲D將自增值設(shè)置為比自增列中的最大值還要小的值的時(shí)候,自增值會(huì)自動(dòng)變?yōu)樽栽隽械淖畲笾?+1 的值,如下圖所示:

圖片

3、一個(gè)表可以有多個(gè)自增列嗎?

一個(gè)表中只能有一個(gè)自增列,這和一個(gè)表只能有一個(gè)主鍵的規(guī)則類似,當(dāng)我們嘗試給一個(gè)表添加一個(gè)自增列時(shí),可以正常添加成功,如下圖所示:

圖片

圖片當(dāng)我們嘗試給一個(gè)表添加多個(gè)自增列時(shí),會(huì)提示只能有一個(gè)自增列的報(bào)錯(cuò)信息,如下圖所示:圖片

圖片

4、其他注意事項(xiàng)

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

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

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

圖片

圖片當(dāng)我們使用其他類型來作為自增列的數(shù)據(jù)類型時(shí),會(huì)提示如下錯(cuò)誤:

圖片圖片

(2)必須配合 key 一起使用

auto_increment 必須配合 key 一起使用,這個(gè) key 可以是 primary key 或 foreign key,如果沒有 key 就會(huì)報(bào)錯(cuò),如下所示:

圖片

PS:auto_increment 也可以配合唯一約束 unique 一起使用。

總結(jié)

自增列的值默認(rèn)是 1,每次遞增 1,但也可以在創(chuàng)建表的時(shí)候手動(dòng)指定自增值,當(dāng)然在特殊情況下我們?cè)诒肀粍?chuàng)建之后,也可以通過 alter 修改自增值。一個(gè)表中只能有一個(gè)自增列,就像一個(gè)表中只能有一個(gè)主鍵一樣,如果設(shè)置多個(gè)自增列,那么 SQL 執(zhí)行就會(huì)報(bào)錯(cuò)。除此之外還要注意自增列應(yīng)該為整數(shù)類型,且 auto_increment 需要配合 key 一起使用,這個(gè) key 可以是 primary key 或 foreign key。

責(zé)任編輯:姜華 來源: Java面試真題解析
相關(guān)推薦

2010-11-11 12:06:39

SQL自增列

2020-03-09 09:07:51

Vue根節(jié)點(diǎn)Fragments

2022-04-11 07:40:45

synchroniz靜態(tài)方法程序

2022-07-11 07:10:48

HTTP協(xié)議類型

2010-11-03 15:56:13

DB2創(chuàng)建表

2022-05-05 07:38:32

volatilJava并發(fā)

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

單例模式懶漢模式靜態(tài)內(nèi)部類

2022-09-19 06:16:23

事務(wù)隔離級(jí)別Spring

2022-04-18 07:36:37

TimeUnit線程休眠

2022-05-11 07:41:55

死鎖運(yùn)算線程

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-04-24 07:59:53

synchronizJVMAPI

2022-08-10 07:06:57

IoCDISpring

2022-02-08 07:02:32

進(jìn)程線程操作系統(tǒng)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)