亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關(guān)于mysql自增id,你需要知道的

 更新時間:2020年08月11日 10:52:40   作者:MySQL技術(shù)  
這篇文章主要介紹了關(guān)于mysql自增id的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)mysql,感興趣的朋友可以了解下

導(dǎo)讀:在使用MySQL建表時,我們通常會創(chuàng)建一個自增字段(AUTO_INCREMENT),并以此字段作為主鍵。本篇文章將以問答的形式講述關(guān)于自增id的一切。

注: 本文所講的都是基于Innodb存儲引擎。

1.MySQL為什么建議將自增列id設(shè)為主鍵?

  • 如果我們定義了主鍵(PRIMARY KEY),那么InnoDB會選擇主鍵作為聚集索引、如果沒有顯式定義主鍵,則InnoDB會選擇第一個不包含有NULL值的唯一索引作為主鍵索引、如果也沒有這樣的唯一索引,則InnoDB會選擇內(nèi)置6字節(jié)長的ROWID作為隱含的聚集索引(ROWID隨著行記錄的寫入而主鍵遞增,這個ROWID不像ORACLE的ROWID那樣可引用,是隱含的)。
  • 數(shù)據(jù)記錄本身被存于主索引(一顆B+Tree)的葉子節(jié)點上。這就要求同一個葉子節(jié)點內(nèi)(大小為一個內(nèi)存頁或磁盤頁)的各條數(shù)據(jù)記錄按主鍵順序存放,因此每當(dāng)有一條新的記錄插入時,MySQL會根據(jù)其主鍵將其插入適當(dāng)?shù)墓?jié)點和位置,如果頁面達到裝載因子(InnoDB默認為15/16),則開辟一個新的頁(節(jié)點)
  • 如果表使用自增主鍵,那么每次插入新的記錄,記錄就會順序添加到當(dāng)前索引節(jié)點的后續(xù)位置,當(dāng)一頁寫滿,就會自動開辟一個新的頁
  • 如果使用非自增主鍵(如果身份證號或?qū)W號等),由于每次插入主鍵的值近似于隨機,因此每次新紀錄都要被插到現(xiàn)有索引頁得中間某個位置,此時MySQL不得不為了將新記錄插到合適位置而移動數(shù)據(jù),甚至目標(biāo)頁面可能已經(jīng)被回寫到磁盤上而從緩存中清掉,此時又要從磁盤上讀回來,這增加了很多開銷,同時頻繁的移動、分頁操作造成了大量的碎片,得到了不夠緊湊的索引結(jié)構(gòu),后續(xù)不得不通過OPTIMIZE TABLE來重建表并優(yōu)化填充頁面。

綜上而言:當(dāng)我們使用自增列作為主鍵時,存取效率是最高的。

2.自增列id一定是連續(xù)的嗎?

自增id是增長的 不一定連續(xù)。

我們先來看下MySQL 對自增值的保存策略:

InnoDB 引擎的自增值,其實是保存在了內(nèi)存里,并且到了 MySQL 8.0 版本后,才有了“自增值持久化”的能力,也就是才實現(xiàn)了“如果發(fā)生重啟,表的自增值可以恢復(fù)為 MySQL 重啟前的值”,具體情況是:
在 MySQL 5.7 及之前的版本,自增值保存在內(nèi)存里,并沒有持久化。每次重啟后,第一次打開表的時候,都會去找自增值的最大值 max(id),然后將 max(id)+1 作為這個表當(dāng)前的自增值。
舉例來說,如果一個表當(dāng)前數(shù)據(jù)行里最大的 id 是 10,AUTO_INCREMENT=11。這時候,我們刪除 id=10 的行,AUTO_INCREMENT 還是 11。但如果馬上重啟實例,重啟后這個表的 AUTO_INCREMENT 就會變成 10。
也就是說,MySQL 重啟可能會修改一個表的 AUTO_INCREMENT 的值。
在 MySQL 8.0 版本,將自增值的變更記錄在了 redo log 中,重啟的時候依靠 redo log 恢復(fù)重啟之前的值。

造成自增id不連續(xù)的情況可能有:

  • 1.唯一鍵沖突
  • 2.事務(wù)回滾
  • 3.insert ... select語句批量申請自增id

3.自增id有上限嗎?

自增id是整型字段,我們常用int類型來定義增長id,而int類型有上限 即增長id也是有上限的。

下表列舉下 int 與 bigint 字段類型的范圍:

類型 大小 范圍(有符號) 范圍(無符號)
int 4字節(jié) (-2147483648,2147483647) (0,4294967295)
bigint 8字節(jié) (-9223372036854775808,9223372036854775807) (0,18446744073709551615)

從上表可以看出:當(dāng)自增字段使用int有符號類型時,最大可達2147483647即21億多;使用int無符號類型時,最大可達4294967295即42億多。當(dāng)然bigint能表示的范圍更大。

下面我們測試下當(dāng)自增id達到最大時再次插入數(shù)據(jù)會怎么樣:

create table t(id int unsigned auto_increment primary key) auto_increment=4294967295;insert into t values(null);// 成功插入一行 4294967295show create table t;/* CREATE TABLE `t` (`id` int(10) unsigned NOT NULL AUTO_INCREMENT,PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=4294967295;*/
insert into t values(null);//Duplicate entry '4294967295' for key 'PRIMARY'

從實驗可以看出,當(dāng)自增id達到最大時將無法擴展,第一個 insert 語句插入數(shù)據(jù)成功后,這個表的AUTO_INCREMENT 沒有改變(還是 4294967295),就導(dǎo)致了第二個 insert 語句又拿到相同的自增 id 值,再試圖執(zhí)行插入語句,報主鍵沖突錯誤。

4.關(guān)于自增列 我們該怎么維護?

維護方面主要提供以下2點建議:

  • 1.字段類型選擇方面:推薦使用int無符號類型,若可預(yù)測該表數(shù)據(jù)量將非常大 可改用bigint無符號類型。
  • 2.多關(guān)注大表的自增值,防止發(fā)生主鍵溢出情況。

以上就是關(guān)于mysql自增id,你需要知道的的詳細內(nèi)容,更多關(guān)于mysql自增id的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • K8s 如何部署 MySQL 8.0.20 主從復(fù)制結(jié)構(gòu)

    K8s 如何部署 MySQL 8.0.20 主從復(fù)制結(jié)構(gòu)

    這篇文章主要介紹了K8s 如何部署 MySQL 8.0.20 主從復(fù)制結(jié)構(gòu),本次使用 OpenEBS 來作為存儲引擎,OpenEBS 是一個開源的、可擴展的存儲平臺,它提供了一種簡單的方式來創(chuàng)建和管理持久化存儲卷,需要的朋友可以參考下
    2024-04-04
  • 數(shù)據(jù)庫工具sysbench安裝教程和性能測試例子

    數(shù)據(jù)庫工具sysbench安裝教程和性能測試例子

    這篇文章主要介紹了數(shù)據(jù)庫工具sysbench安裝教程和性能測試例子,sysbench的一個簡明入門教程,包含編譯安裝過程和主要測試數(shù)據(jù),需要的朋友可以參考下
    2014-07-07
  • Express連接MySQL及數(shù)據(jù)庫連接池技術(shù)實例

    Express連接MySQL及數(shù)據(jù)庫連接池技術(shù)實例

    數(shù)據(jù)庫連接池是程序啟動時建立足夠數(shù)量的數(shù)據(jù)庫連接對象,并將這些連接對象組成一個池,由程序動態(tài)地對池中的連接對象進行申請、使用和釋放,本文重點給大家介紹Express連接MySQL及數(shù)據(jù)庫連接池技術(shù),感興趣的朋友一起看看吧
    2022-02-02
  • MySQL的Data_ADD函數(shù)與日期格式化函數(shù)說明

    MySQL的Data_ADD函數(shù)與日期格式化函數(shù)說明

    今天看到了MySQL的日期函數(shù),里面很多有用的,這里只把兩個參數(shù)不太好記的粘下來了。
    2010-06-06
  • mysql行鎖(for update)解決高并發(fā)問題

    mysql行鎖(for update)解決高并發(fā)問題

    這篇文章主要介紹了mysql行鎖(for update)解決高并發(fā)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • MySQL?5.7壓縮包安裝圖文教程(超詳細)

    MySQL?5.7壓縮包安裝圖文教程(超詳細)

    這篇文章主要介紹了MySQL?5.7壓縮包安裝圖文教程(超詳細),本文通過圖文結(jié)合的方式給大家介紹的非常詳細,感興趣的朋友跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧
    2024-05-05
  • MySQL隔離級別和鎖機制的深入講解

    MySQL隔離級別和鎖機制的深入講解

    這篇文章主要給大家介紹了關(guān)于MySQL隔離級別和鎖機制的相關(guān)資料,主要包括深入理解MySQL隔離級別和鎖機制使用實例、應(yīng)用技巧、基本知識點總結(jié)和需要注意事項,需要的朋友可以參考下
    2021-08-08
  • mysql5.6.8源碼安裝過程

    mysql5.6.8源碼安裝過程

    這篇文章主要介紹了mysql5.6.8源碼安裝過程,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-01-01
  • sql和MySQL的語句執(zhí)行順序分析

    sql和MySQL的語句執(zhí)行順序分析

    本文就sql和mysql的語句執(zhí)行順序問題向大家作了詳細介紹,小編覺得挺不錯的,這里分享下,供大家參考。
    2017-10-10
  • Windows 下noinstall方式安裝 mysql 5.7.5 m15 winx64(推薦)

    Windows 下noinstall方式安裝 mysql 5.7.5 m15 winx64(推薦)

    這篇文章主要介紹了Windows 下noinstall方式安裝 mysql-5.7.5-m15-winx64的相關(guān)資料,非常不錯,具有參考借鑒價值,感興趣的朋友一起看看吧
    2016-09-09

最新評論