MySQL新增自增主鍵的坑
很多不規範的系統,由於各種各樣的原因可能一開始沒有主鍵,後面接手的dba,在推動規範化的時候,可能需要對這些表新增自增主鍵,在新增自增主鍵的時候,很可能會踩到這個坑。
bug: 92949
## Use two concurrent connecitons on master ## Insert in each connection, and make sure the insert order is different ## from commit order. connect(conn1,localhost,root,,test,$MASTER_MYPORT,); connect(conn2,localhost,root,,test,$MASTER_MYPORT,); connection conn1; create table t1(tid int, name varchar(30), index idx_tid(tid)) engine=InnoDB; ## conn1 insert first begin; insert into t1 values (1, 'fun'); ## conn2 insert later, but commit first connection conn2; begin; insert into t1 values (2, 'go'); commit; ## but conn1 commit later connection conn1; commit; ## check what we have on master and slave connection master; select * from t1; --sync_slave_with_master connection slave; select * from t1; ## the above shows records on M and S are in different order ## add a auto_increment column as PK connection master; alter table t1 add column id int not null auto_increment primary key; select * from t1; checksum table t1; --sync_slave_with_master connection slave; select * from t1; checksum table t1; ## the above show records on M and S are different now
透過解析資料檔案,在master與slave上,2個記錄在cluster index上的位置不一樣,2個記錄的位置是互換的,在加主鍵的時候,alter 在rebuild的過程中,按cluster上儲存的順序,讀取插入,從而導致主鍵id 對應的記錄在主從庫不匹配。
給出的解決方式是
Workaround: # Instead of ALTER TABLE t ADD COLUMN # c INT NOT NULL AUTO_INCREMENT PRIMARY KEY: ALTER TABLE t ADD COLUMN c INT NOT NULL; SET @c = 0; UPDATE t SET c = (@c := @c + 1); ALTER TABLE t ADD PRIMARY KEY(c); ALTER TABLE t CHANGE c c INT NOT NULL AUTO_INCREMENT;
透過先加一個欄位,然後透過給這個欄位賦值的方式,給正確的值,然後在設定這個欄位成自增主鍵。
檢視程式碼,從庫在執行事件的時候,使用了index_scan的方式
decide_row_lookup_algorithm_and_key: info: decide_row_lookup_algorithm_and_key: decided - INDEX_SCAN
在master上執行的時候更新c的時候是按cluster上存放的順序更新的,透過binlog event傳播到從庫,這樣c的記錄在master,slave上就變成一致的了,後面在設定成主鍵。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/25719946/viewspace-2933173/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- MySQL 主鍵自增也有坑?MySql
- MySQL 中的自增主鍵MySql
- 向Mysql主鍵自增長表中新增資料並返回主鍵MySql
- Mysql關於自增主鍵,自增主鍵優化總結MySql優化
- MySQL 主鍵自增 Auto Increment用法MySqlREM
- 深入瞭解MySQL中的自增主鍵MySql
- MySQL8自增主鍵變化MySql
- MySQL自增主鍵跳號問題MySql
- mybatis入門程式:向資料庫中新增使用者&&自增主鍵和非自增主鍵的返回MyBatis資料庫
- MySQL 8 新特性之自增主鍵的持久化MySql持久化
- postgresql自增主鍵SQL
- MySQL 資料庫自增主鍵生成的優缺點MySql資料庫
- 使用Spring JDBC新增記錄如何返回自增主鍵值SpringJDBC
- mysql-刪除和新增主鍵MySql
- java面試一日一題:mysql中的自增主鍵Java面試MySql
- select @@Identity 返回自增主鍵的值IDE
- PostgreSQL 建立主鍵自增表的 DDLSQL
- postgresql重置序列和自增主鍵SQL
- PostgreSQL建立自增主鍵的兩種方法SQL
- MyBatis的Insert操作自增主鍵的實現,Mysql協議與JDBC實現MyBatisMySql協議JDBC
- SqlServer主鍵和自增長設定SQLServer
- MogDB/openGauss如何實現自增主鍵
- Laravel 中使用 Redis 生成自增主鍵LaravelRedis
- Mybatis:插入資料返回自增主鍵MyBatis
- [MySQL]為什麼主鍵最好是有序遞增的MySql
- MySQL怎麼利用函式和觸發器實現非主鍵自增?MySql函式觸發器
- sysbench花式採坑之二:自增值導致的主鍵衝突
- mysql預先取自動增長主鍵的下一個值MySql
- Mybatis-Plus3.0預設主鍵策略導致自動生成19位長度主鍵id的坑MyBatisS3
- 主鍵的建立、新增、刪除操作
- 資料表設計之主鍵自增、UUID或聯合主鍵UI
- mysql自增和orcale自增MySql
- 面試官竟然問我訂單ID是怎麼生成的?難道不是MySQL自增主鍵?面試MySql
- DB2巧用欄位自動增長主鍵的方法DFDB2
- Mybatis獲取自增主鍵的值MyBatis
- MySQL新增列、刪除列,建立主鍵等常用操作總結MySql
- SQLite設定主鍵自動增長及插入語法SQLite
- 自增長主鍵回顯實現,批次資料插入