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

MySQL自增ID,居然大部分人都搞錯了!?

數據庫 MySQL
《MySQL刪除數據的三種方式》中的作業題,99%的人答錯,有點出乎意料。今天簡單說下作業題中的答案,以及知識點。

《??MySQL刪除數據的三種方式??》中的作業題,99%的人答錯,有點出乎意料。畫外音:評論中不乏嘲笑知識點簡單的小伙伴。

今天簡單說下作業題中的答案,以及知識點。

作業題是這樣的:

實驗步驟如上圖:

  • 第一步:建表,設定自增列;
  • 第二步:指定id=1插入,錨定第一行是id是1;
  • 第三步:不指定id,依賴自增機制,插入3行;畫外音:此時id應該變為2,3,4了?
  • 第四步:delete刪除所有記錄;畫外音:坑就容易出在這里。
  • 第五步:指定id=0插入;
  • 第六步:指定id=1插入;
  • 第七步:不指定id,依賴自增機制,插入1行;

請問,此時表中的三行記錄,id分別是多少?

知識點一:delete數據后,自增列計數不會從頭開始。

畫外音:truncate數據后,自增列計數會從頭開始。

因此,在第四步delete刪除所有4條記錄后,自增列計數,并不會重新歸0,也就是說,下一條insert的記錄,自增列的值會是5。

知識點二:含自增列的表,插入時可以手動指定自增列的值,但不能與已有值沖突,也可以使用系統默認自增列的值。

因此,第五、六、七步都是允許的:

insert (0, '000')
insert (1, '111')
insert ('222')

知識點三:如果手動指定自增列的值是0或者NULL,MySQL會視為無效,并使用系統默認自增列的值。

也就是說,第五步insert (0, '000') 又或者 insert (NULL, '000')都會被MySQL視為:

insert ('000')

即,實際插入到表中的記錄是

(5, '000')

第六步insert (1, '111')沒有問題

實際插入的也是

(1, '111')

知識點四:如果使用系統默認自增列的值,會從當前最大值開始往后增加。

也就是說,第七步insert ('222'),會使用默認值6,而不是2。

實際插入的是

(6, '222')

故,實驗結果,最終的三行記錄是:

5,000
1,111
6,222

你答對了嗎?

為了鞏固下上面的知識點,咱們一起來復習一下:

drop table t1;
create table t1(
id int not null auto_increment,
name varchar(10) unique,
count int default 0,
primary key(id),
index(name)
)engine=innodb;

insert into t1(id, name) values(1, "shenjian");

insert into t1(id, name) values
(111, "111"),(NULL, "abc"),(222, "222"),(NULL,"xyz");

請問,執行結束后id分別是多少呢?

答案:

(1, 'shenjian')
(111, '111') // 允許指定值
(112, 'abc') // 忽略NULL,從最大值開始增
(222, '222') // 允許指定值
(223, 'xyz') // 忽略NULL,從最大值開始增

上題如果繼續執行以下語句:

insert into t1(name)values("shenjian"),("aaa"),("bbb")
on duplicate key update count=100;

請問:

  • 會不會執行報錯?
  • 如果報錯,為什么呢?
  • 如果不報錯,得到的數據是什么呢?

知其然,更知其底層所以然。

責任編輯:趙寧寧 來源: 架構師之路
相關推薦

2019-10-11 10:05:30

程序員固態硬盤Google

2021-10-14 06:51:54

SpringSecurityJWT

2025-01-26 16:04:09

2024-09-04 01:36:51

Java對象傳遞

2021-08-06 17:44:45

云安全云計算網絡安全

2018-11-25 21:53:10

人工智能AI開發者

2012-06-07 16:16:43

JavaScript

2013-07-30 11:15:35

NASA云計算安全云計算

2016-12-12 18:45:08

Data Mining大數據

2016-10-26 10:23:42

2023-02-07 13:51:11

SQLupdate語句

2021-03-15 08:02:43

線性結構PriorityQue

2019-09-12 09:56:13

程序員技能開發者

2016-12-22 08:38:21

2011-12-26 17:13:18

iPad統計App

2015-11-25 10:48:44

JS閉包面試題

2023-08-07 11:56:43

模型人貨場數據

2024-07-05 11:50:15

2025-06-04 11:06:54

比特幣區塊鏈挖礦

2018-08-31 07:33:58

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 少妇av片| 精品国产精品三级精品av网址 | 亚洲精品欧美 | 精品一二三区视频 | 久久99久久久久 | a国产一区二区免费入口 | 精品在线一区 | 2022国产精品 | 人人人人爽| 久久久精品视 | 久久精品中文字幕 | 在线91| 日韩另类 | 欧美在线a | 一区二区欧美在线 | 精品国产乱码久久久久久丨区2区 | 日韩在线免费播放 | 另类视频区 | 一区二区国产在线 | 盗摄精品av一区二区三区 | 91免费看片| 精品国产一区二区三区性色av | 无吗视频 | 日韩成人在线电影 | 天天夜干 | 日韩av三区 | www精品| 精品亚洲一区二区三区四区五区 | 成人精品一区二区三区中文字幕 | 99免费精品视频 | 伊人中文字幕 | 亚洲欧美少妇 | 91在线观看免费 | 欧美成人a∨高清免费观看 色999日韩 | 日本中文字幕视频 | 久草视频观看 | 精品国产精品三级精品av网址 | 亚洲成人一级片 | 国产日韩欧美一区二区 | 一区二区视频在线 | 国产三级精品三级在线观看四季网 |