MySQL 複製 主鍵衝突

來源:互聯網
上載者:User

標籤:replace   master   values   網上   

看了下複製的問題,最明顯的一個案例就是主鍵衝突,今天就看下這個問題

  1. 什麼原因會導致這個問題

  2. 怎麼規避這個問題

一、什麼原因導致

網上最多的說就是:對於存在auto_increment欄位或者unique索引欄位,使用replace into操作或者主從切換,因為replace into對於auto或者unique欄位會進行刪除再做插入

執行replace into t values(1,2)被刪除和被插入的行數的和(大於或者等於1)

master 上 SHOW CREATE TABLE `test_autoinc` (

  `id` int(11) NOT NULL AUTO_INCREMENT,

  `c1` int(11) DEFAULT NULL,

  `c2` varchar(100) DEFAULT NULL,

  PRIMARY KEY (`id`),

  UNIQUE KEY `c1` (`c1`)

) ENGINE=InnoDBAUTO_INCREMENT=7

slave 上 SHOW CREATE TABLE `test_autoinc` (

  `id` int(11) NOT NULL AUTO_INCREMENT,

  `c1` int(11) DEFAULT NULL,

  `c2` varchar(100) DEFAULT NULL,

  PRIMARY KEY (`id`),

  UNIQUE KEY `c1` (`c1`)

) ENGINE=InnoDBAUTO_INCREMENT=6

可以看到執行了replace into之後會發現欄位增長不一樣了,此時master的自增列為7,而slave的自增列為6,與表內最大值相同,若發生主備切換,slave提供服務,此時通過自增列插入主鍵6的記錄,就會發生主鍵衝突

解決的辦法有兩個:

1st suggested fix is: use a delete event and a insert event  to record this replace.2nd suggested fix is: update the auto_incrment in update statements.

我看有的解決是這樣的,但是不知道在資料庫怎麼實現的

if not exists ( select phone from t where phone= ‘1‘ )              insert into t(phone, update_time) values ( ‘1‘ , getdate())   else

          update t set update_time = getdate() where phone= ‘1‘



MySQL 複製 主鍵衝突

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.