MySQL?8.0自增變量的持久化問題小結
MySQL 8.0特性-自增變量的持久化
在MySQL 8.0之前,自增主鍵AUTO_INCREMENT的值如果大于max(primary key)+1,在MySQL重啟后,會重置AUTO_INCREMENT=max(primary key)+1,這種現象在某些情況下會導致業(yè)務主鍵沖突或者其他難以發(fā)現的問題。 下面通過案例來對比不同的版本中自增變量是否持久化。
MySQL5.7測試
在MySQL 5.7版本中,測試步驟如下: 創(chuàng)建的數據表中包含自增主鍵的id字段,語句如下:
CREATE TABLE test1( id INT PRIMARY KEY AUTO_INCREMENT ); -- 插入4個空值,執(zhí)行如下: INSERT INTO test1 VALUES(0),(0),(0),(0); -- 查詢數據表test1中的數據,結果如下: mysql> SELECT * FROM test1; +----+ | id | +----+ | 1 | | 2 | | 3 | | 4 | +----+ 4 rows in set (0.00 sec) -- 刪除id為4的記錄,語句如下: DELETE FROM test1 WHERE id = 4; -- 再次插入一個空值,語句如下: INSERT INTO test1 VALUES(0); -- 查詢此時數據表test1中的數據,結果如下: mysql> SELECT * FROM test1; +----+ | id | +----+ | 1 | | 2 | | 3 | | 5 | +----+ 4 rows in set (0.00 sec) -- 從結果可以看出,雖然刪除了id為4的記錄,但是再次插入空值時,并沒有重用被刪除的4,而是分配了5。 -- 刪除id為5的記錄 DELETE FROM test1 where id=5;
重啟數據庫
service mysql stop service mysql start
繼續(xù)插入空值,然后再次查詢數據表test1中的數據,結果如下:
mysql> INSERT INTO test1 values(0); Query OK, 1 row affected (0.00 sec) mysql> select * from test1; +----+ | id | +----+ | 1 | | 2 | | 3 | | 4 | +----+ 4 rows in set (0.00 sec)
從結果可以看出,新插入的0值分配的是4,按照重啟前的操作邏輯,此處應該分配6。出現上述結果的主要原因是自增主鍵沒有持久化。 在MySQL 5.7系統中,對于自增主鍵的分配規(guī)則,是由InnoDB數據字典內部一個 計數器 來決定的,而該計數器只在 內存中維護 ,并不會持久化到磁盤中。當數據庫重啟時,該計數器會被初始化。
MySQL 8.0測試
上述測試步驟最后一步的結果如下:
mysql> select * from test1; +----+ | id | +----+ | 1 | | 2 | | 3 | | 6 | +----+ 4 rows in set (0.00 sec)
從結果可以看出,自增變量已經持久化了。
MySQL 8.0將自增主鍵的計數器持久化到 重做日志中。每次計數器發(fā)生改變,都會將其寫入重做日志中。如果數據庫重啟,InnoDB會根據重做日志中的信息來初始化計數器的內存值。
到此這篇關于MySQL 8.0自增變量的持久化的文章就介紹到這了,更多相關mysql自增變量內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
mysql通過frm和ibd文件恢復表_mysql5.7根據.frm和.ibd文件恢復表結構和數據
文章主要介紹了如何從.frm和.ibd文件恢復MySQL InnoDB表結構和數據,需要的朋友可以參考下2025-03-03
CentOS6.9下mysql 5.7.17安裝配置方法圖文教程
這篇文章主要為大家詳細介紹了CentOS6.9下mysql 5.7.17安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10
通過sysbench工具實現MySQL數據庫的性能測試的方法
sysbench是一款壓力測試工具,可以測試系統的硬件性能,也可以用來對數據庫進行基準測試。這篇文章主要介紹了通過sysbench工具實現MySQL數據庫的性能測試 ,需要的朋友可以參考下2019-07-07
mysql 8.0.22壓縮包完整安裝與配置教程圖解(親測安裝有效)
這篇文章主要介紹了mysql 8.0.22壓縮包完整安裝與配置教程圖解(親測安裝有效),本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-12-12

