日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
MySQL自增ID,居然大部分人都搞錯了!?

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

專注于為中小企業(yè)提供網(wǎng)站制作、成都網(wǎng)站設計服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)昭化免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了上千余家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。

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

作業(yè)題是這樣的:

實驗步驟如上圖:

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

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

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

畫外音:truncate數(shù)據(jù)后,自增列計數(shù)會從頭開始。

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

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

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

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

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

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

insert ('000')

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

(5, '000')

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

實際插入的也是

(1, '111')

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

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

實際插入的是

(6, '222')

故,實驗結(jié)果,最終的三行記錄是:

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");

請問,執(zhí)行結(jié)束后id分別是多少呢?

答案:

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

上題如果繼續(xù)執(zhí)行以下語句:

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

請問:

  • 會不會執(zhí)行報錯?
  • 如果報錯,為什么呢?
  • 如果不報錯,得到的數(shù)據(jù)是什么呢?

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


分享文章:MySQL自增ID,居然大部分人都搞錯了???
瀏覽地址:http://www.dlmjj.cn/article/djihoge.html