婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL InnoDB row_id邊界溢出驗證的方法步驟

MySQL InnoDB row_id邊界溢出驗證的方法步驟

熱門標簽:走過哪個省地圖標注 銷售語音電話機器人 安徽ai電話電銷機器人有效果嗎 在哪里申請400電話 萊西市地圖標注 巫師三血與酒地圖標注 常州網(wǎng)絡外呼系統(tǒng)開發(fā) 400電話申請信用卡 外呼系統(tǒng)電銷受騙

背景

跟同學聊到row_id一個邊界問題,這里詳細說明下。

InnoDB表若沒有定義主鍵,會使用系統(tǒng)的一個默認遞增row_id (dict_sys->row_id)作為主鍵。每次插入一行加1,到達最大值循環(huán)復用。

需要注意的是,雖然dict_sys->row_id 被定義為一個unsigned long long, 但由于這個主鍵值只有6個字節(jié),因此最大值是2^48。 row_id超過這個值還是會遞增,只是寫入的時候只取低位,可以認為是做取模操作。

問題

這就涉及到一個問題,一個長期運行的MySQL里,如果頻繁插入刪除行(像日志類的表),即使最終表規(guī)模不是很大,仍可能會出現(xiàn)值row_id重用。而我們知道作為主鍵值,是不能重復的。

假設出現(xiàn)這種情況,在一個表里,新插入的一行的row_id與某一個年代久遠的行的row_id出現(xiàn)沖突,會腫么樣?

驗證

其實本來這里只需要一個結論。本文的目的還是跟大家探討一種驗證的方法。有了上面的信息,我們可以考慮設計如下的復現(xiàn)步驟:

1)    創(chuàng)建一張無主鍵空表

2)   gdb設置dict_sys->row_id為1

3)  往空表插入若干行

4)   gdb設置dict_sys->row_id為2^48

5)   再插入若干行

6)   看結果

結論

可以看到,行(1),(2)被覆蓋了。

比較合理點的方案應該是像MySQL的表內自增主鍵一樣,報個duplicate-key error.

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • Mysql InnoDB和MyISAM區(qū)別原理解析
  • 獲取 MySQL innodb B+tree 的高度的方法
  • MySQL MyISAM 與InnoDB 的區(qū)別
  • 簡述MySQL InnoDB存儲引擎
  • MySQL Innodb 存儲結構 和 存儲Null值 用法詳解
  • MySQL InnoDB如何保證事務特性示例詳解
  • MySQL啟動報錯問題InnoDB:Unable to lock/ibdata1 error
  • MySQL InnoDB中的鎖機制深入講解
  • 詳解MySQL(InnoDB)是如何處理死鎖的
  • MySQL學習(七):Innodb存儲引擎索引的實現(xiàn)原理詳解
  • MySQL slow_log表無法修改成innodb引擎詳解
  • mysql innodb的重要組件匯總

標簽:鞍山 陽江 果洛 煙臺 赤峰 來賓 黃石 河北

巨人網(wǎng)絡通訊聲明:本文標題《MySQL InnoDB row_id邊界溢出驗證的方法步驟》,本文關鍵詞  MySQL,InnoDB,row,邊界,溢出,;如發(fā)現(xiàn)本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL InnoDB row_id邊界溢出驗證的方法步驟》相關的同類信息!
  • 本頁收集關于MySQL InnoDB row_id邊界溢出驗證的方法步驟的相關信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 那坡县| 凤台县| 顺平县| 丰城市| 五家渠市| 会理县| 江西省| 平度市| 忻州市| 日喀则市| 天祝| 洛隆县| 霍州市| 边坝县| 合作市| 申扎县| 天镇县| 柘城县| 措美县| 米易县| 昂仁县| 新闻| 武安市| 通榆县| 建昌县| 九江县| 盐城市| 应用必备| 黑水县| 景泰县| 道孚县| 苍南县| 会昌县| 饶平县| 二连浩特市| 岳西县| 武冈市| 福建省| 府谷县| 克拉玛依市| 昌乐县|