欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql自增長id用完了該怎么辦

 更新時(shí)間:2022年02月11日 11:30:40   作者:愛開發(fā)V  
如果你用過或了解過MySQL,那你一定知道自增主鍵了,下面這篇文章主要給大家介紹了關(guān)于mysql自增長id用完了該怎么辦的相關(guān)資料,需要的朋友可以參考下

mysql自增長id用完了,怎么辦?

作為一名程序員,在求職面試時(shí),不知你有沒有遇到類似這樣的問題。

張工是一名java程序員,最近到一家互聯(lián)網(wǎng)公司面試,面試官就問了他這樣的一個(gè)問題。

面試官:"用過mysql吧,你們數(shù)據(jù)表主鍵id是用自增主鍵還是UUID?"   

張工:"用的是自增主鍵"    

面試官:"為什么是自增主鍵?"    

張工:"因?yàn)椴捎米栽鲋麈I,數(shù)據(jù)在物理結(jié)構(gòu)上是順序存儲(chǔ),性能好"    

面試官:"那自增主鍵達(dá)到最大值了,用完了怎么辦?"    

張工:“用完了就用完了,再申請唄”

面試官:“你可以回去等通知了”

今天我們就來談一談,這個(gè)自增主鍵用完了該怎么辦?

在mysql,int整型的范圍如下int的取值范圍為:-2^31——2^31-1,即-2147483648—2147483647

如圖:

cec642de02c5612df27ac603ab76147b.png

以無符號整型為例,存儲(chǔ)范圍為0~4294967295,約43億。當(dāng)自增id達(dá)到最大值時(shí),這是繼續(xù)插入會(huì)出現(xiàn)什么異常呢,

我們來動(dòng)手實(shí)踐下。

首先,創(chuàng)建一張表tb_user,這張表只包含一個(gè)自增id

create table  tb_user(id int unsigned auto_increment primary key) ;

然后向這張表插入一條數(shù)據(jù):

insert into tb_user values(null);

通過show命令show create table tb_user;查看表情況:

CREATE TABLE `tb_user` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8

細(xì)心的你會(huì)發(fā)現(xiàn) AUTO_INCREMENT 已經(jīng)變成2,不過這離最大值4294967295遠(yuǎn)著呢,要想讓它變成4294967295得插入非常多的記錄,其實(shí)不用這么麻煩,我們可以在創(chuàng)建表的時(shí)候,直接聲明AUTO_INCREMENT的初始值。

把我們剛才的創(chuàng)建表語句調(diào)整下,先把剛才的表刪除掉,然后在創(chuàng)建表時(shí)加上auto_increment = 4294967295

create table tb_user(id int unsigned auto_increment primary key) auto_increment = 4294967295;

 然后同樣往表插入一條記錄

insert into tb_user values(null);

同樣,我們通過show命令,查看表tb_user的表結(jié)構(gòu):

CREATE TABLE `tb_user` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=4294967295 DEFAULT CHARSET=utf8

通過

select * from tb_user

我們查詢到id 為4294967295,已經(jīng)是最大值,這時(shí)候如果再

當(dāng)想往表在嘗試插入一條數(shù)據(jù)時(shí),報(bào)一個(gè)主鍵沖突異常如下所示。

[SQL]insert into tb_user values(null);
[Err] 1062 - Duplicate entry '4294967295' for key 'PRIMARY'

這可以說明,當(dāng)再次插入時(shí),使用的自增ID還是4294967295,就會(huì)報(bào)主鍵沖突的異常了。

4294967295,這個(gè)數(shù)字已經(jīng)可以應(yīng)付大部分的場景了,如果你的服務(wù)會(huì)經(jīng)常性的插入和刪除數(shù)據(jù)的話,還是存在用完的風(fēng)險(xiǎn)。

建議采用bigint unsigned,這個(gè)數(shù)字就大了。

那有什么辦法解決,答案是肯定的,解決方法也是很簡單的,將Int類型改為BigInt類型,BigInt的范圍如下

-2^63-1到2^63-1

-9223372036854775808  9223372036854775807

60b16171c8fd2871721816a21e683447.png

就算每秒往數(shù)據(jù)表插入10000條數(shù)據(jù),運(yùn)行100年,來看看數(shù)據(jù)量有多少

10000*24*3600*365*100=31536000000000

這數(shù)字距離BigInt的上限還差的遠(yuǎn),因此你將自增ID設(shè)為BigInt類型,就可以解決問題了。

如果你在面試中是這樣回答面試官的。

你:"這還不簡單,把自增主鍵的類型改為BigInt類型就可以解決了!"

面試官:"你在線上怎么修改列的數(shù)據(jù)類型的?"   

你:"alter table tb_user change id  id bigint;"

面試官:“你有實(shí)際操作經(jīng)驗(yàn)嗎?”

你:“…………沒有實(shí)際操作過”

需要注意的是,這種方式在myl5.6+才開始支持,mysql支持在線修改數(shù)據(jù)庫表,在修改表的過程中,對絕大部分操作,原表可讀,也可以寫。

對于修改數(shù)據(jù)類型這種操作,是不支持并發(fā)的DML操作!也就是說,如果你直接使用alter這樣的語句在線修改表數(shù)據(jù)結(jié)構(gòu),會(huì)導(dǎo)致這張表無法進(jìn)行更新類操作(delete、update、insert)。所以,想在生產(chǎn)線上執(zhí)行修改表結(jié)構(gòu)這樣的方案是不可行的。

那有沒有更好的方式,對于這個(gè)問題,我們以后再做討論。

不知你有沒有留意到這樣一種情況,雖然主鍵自增ID是從0開始的,也就是說,現(xiàn)在可以用的范圍為0~2147483647,但實(shí)際數(shù)據(jù)中有些id的值并不是連續(xù)的。

要是實(shí)際生產(chǎn)表出現(xiàn)單表超過上億的數(shù)據(jù)量了,這時(shí)候想再往數(shù)據(jù)表寫數(shù)據(jù),性能肯定是受影響了,得趕緊考慮分庫分表了。

一旦分庫分表了,我們就不能依賴于每個(gè)表的自增id來全局唯一標(biāo)識這些數(shù)據(jù)了。此時(shí),我們就需要提供一 個(gè)全局唯一的id號生成策略來支持分庫分表的環(huán)境。

所以在實(shí)際中,根本等不到自增主鍵用完的情況。

較友好的回答不妨參考這樣的

面試官:"那自增主鍵達(dá)到最大值了,用完了怎么辦?"   

你:這問題沒遇到過,因?yàn)樽栽鲋麈I我們用int類型,一般達(dá)不到最大值,就要考慮分表分庫了。

要是面試官窮追不舍,繼續(xù)問你有關(guān)分庫分表的要點(diǎn),你也就可以針對性地回答,說明你完全有這方面的開發(fā)經(jīng)驗(yàn),相信能為這次面試加分。

總結(jié):

mysql數(shù)據(jù)庫表的自增 ID 達(dá)到上限之后,這時(shí)候再申請它的值就不會(huì)在改變了,如果繼續(xù)插入數(shù)據(jù)就會(huì)導(dǎo)致報(bào)主鍵沖突異常。

因此在做數(shù)據(jù)字典設(shè)計(jì)時(shí),要根據(jù)業(yè)務(wù)的需求來選擇合適的字段類型。

到此這篇關(guān)于mysql自增長id用完了該怎么辦的文章就介紹到這了,更多相關(guān)mysql自增長id內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Mysql join連接查詢的語法與示例

    Mysql join連接查詢的語法與示例

    這篇文章主要給大家介紹了關(guān)于Mysql join連接查詢的相關(guān)資料,文中介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • MySQL 4G內(nèi)存服務(wù)器配置優(yōu)化

    MySQL 4G內(nèi)存服務(wù)器配置優(yōu)化

    MySQL對于web架構(gòu)性能的影響最大,也是關(guān)鍵的核心部分。下面我們了解一下MySQL優(yōu)化的一些基礎(chǔ),MySQL自身(my.cnf)的優(yōu)化
    2017-07-07
  • mysql導(dǎo)入導(dǎo)出數(shù)據(jù)的示例詳解

    mysql導(dǎo)入導(dǎo)出數(shù)據(jù)的示例詳解

    本文主要介紹了MySQL 導(dǎo)出和導(dǎo)入數(shù)據(jù)的幾種實(shí)現(xiàn)方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-05-05
  • mysql下為數(shù)據(jù)庫設(shè)置交叉權(quán)限的方法

    mysql下為數(shù)據(jù)庫設(shè)置交叉權(quán)限的方法

    由于 SupeSite 需要調(diào)用 Discuz! 和 UCHome 的數(shù)據(jù),所以如果它們不安裝在同一個(gè)數(shù)據(jù)庫,SupeSite 的數(shù)據(jù)庫用戶必須要對 Discuz! 和 UCHome 的數(shù)據(jù)庫有讀取、修改、刪除等權(quán)限。
    2011-07-07
  • MySQL binlog中的事件類型詳解

    MySQL binlog中的事件類型詳解

    這篇文章主要介紹了MySQL binlog中的事件類型詳解,介紹的非常詳細(xì),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-08-08
  • 圖文詳解Mysql中如何查看Sql語句的執(zhí)行時(shí)間

    圖文詳解Mysql中如何查看Sql語句的執(zhí)行時(shí)間

    寫程序的人往往需要分析所寫的SQL語句是否已經(jīng)優(yōu)化過了,服務(wù)器的響應(yīng)時(shí)間有多快,所以下面這篇文章主要給大家介紹了關(guān)于Mysql中如何查看Sql語句的執(zhí)行時(shí)間的相關(guān)資料,需要的朋友可以參考下
    2021-12-12
  • mysql數(shù)據(jù)庫 主從復(fù)制的配置方法

    mysql數(shù)據(jù)庫 主從復(fù)制的配置方法

    本文主要介紹 mysql數(shù)據(jù)庫 主從負(fù)責(zé)的配置方法,在做數(shù)據(jù)庫開發(fā)的時(shí)候有時(shí)候會(huì)遇到,這里做出詳細(xì)流程,大家可以參考下
    2016-07-07
  • MySQL count(*/column)查詢優(yōu)化的實(shí)現(xiàn)

    MySQL count(*/column)查詢優(yōu)化的實(shí)現(xiàn)

    count()是SQL中一個(gè)常用的聚合函數(shù),其被用來統(tǒng)計(jì)記錄的總數(shù),本文主要介紹了MySQL count(*/column)查詢優(yōu)化的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-09-09
  • 一種簡單的ID生成策略: Mysql表生成全局唯一ID的實(shí)現(xiàn)

    一種簡單的ID生成策略: Mysql表生成全局唯一ID的實(shí)現(xiàn)

    這篇文章主要介紹了一種簡單的ID生成策略: Mysql表生成全局唯一ID的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • MySQL基礎(chǔ)學(xué)習(xí)之約束詳解

    MySQL基礎(chǔ)學(xué)習(xí)之約束詳解

    約束是作用于表中字段上的規(guī)則,用于限制儲(chǔ)存在表中的數(shù)據(jù),這篇文章主要為大家介紹了MySQL中約束的案例以及外鍵約束的展示與刪除,需要的可以參考一下
    2023-07-07

最新評論