關於binlog的冪等性在mysql中的實現思路

由於binlog會有重複拉取的操做,那麼若是後端存儲是mysql,如何處理html

看到微信推了一篇文章,先保存起來mysql


MySQL處理插入過程當中的主鍵惟一鍵重複值辦法

2016-05-05 pursuer.chen 數據庫開發sql

來自:pursuer.chen - 博客園數據庫

做者:pursuer.chen後端

連接:http://www.cnblogs.com/chenmh/p/5392540.html(點擊尾部閱讀原文前往)微信


介紹測試


本篇文章主要介紹在插入數據到表中遇到鍵重複避免插入重複值的處理方法,主要涉及到IGNORE,ON DUPLICATE KEY UPDATE,REPLACE;接下來就分別看看這三種方式的處理辦法。spa


IGNOREhtm


使用ignore當插入的值遇到主鍵(PRIMARY KEY)或者惟一鍵(UNIQUE KEY)重複時自動忽略重複的記錄行,不影響後面的記錄行的插入,blog


建立測試表


CREATE  TABLE  Tignore

(ID INT NOT NULL PRIMARY KEY ,

NAME1 INT

)default charset=utf8;




正常的插入若是插入的記錄中存在鍵重複會報錯,整個語句都會執行失敗




使用IGNORE若是插入的記錄中存在重複值會忽略重複值的該記錄行,不影響其它行的插入。


REPLACE


使用replace當插入的記錄遇到主鍵或者惟一鍵重複時先刪除表中重複的記錄行再插入。


REPLACE   INTO Treplace() VALUES(1,1),(1,2),(2,2);


建立測試表


DROP TABLE  IF EXISTS Treplace;

CREATE  TABLE  Treplace

(ID INT NOT NULL PRIMARY KEY ,

NAME1 INT

)default charset=utf8;




從輸出的信息能夠看到是4行受影響,說明它是先插入了(1,1)而後又刪除了(1,1)


ON DUPLICATE KEY UPDATE


當插入的記錄遇到主鍵或者惟一鍵重複時,會執行後面定義的UPDATE操做。


至關於先執行Insert 操做,再根據主鍵或者惟一鍵執行update操做。


建立測試表


DROP TABLE  IF EXISTS Tupdate;

CREATE  TABLE  Tupdate

(ID INT NOT NULL PRIMARY KEY ,

NAME1 INT UNIQUE KEY

)default charset=utf8;

INSERT INTO Tupdate() VALUES(1,1),(1,2) ON DUPLICATE KEY UPDATE NAME1=NAME1+1;

INSERT INTO Tupdate() VALUES(1,1),(1,2) ON DUPLICATE KEY UPDATE NAME1=VALUES(NAME1)+1;


第一條語句至關於執行:


INSERT INTO Tupdate() VALUES(1,1)

UPDATE Tupdate

SET NAME1=NAME1+1

WHERE ID=1;


第二條語句至關於執行:


INSERT INTO Tupdate() VALUES(1,1)

UPDATE Tupdate

SET NAME1=2+1

WHERE ID=1;


在ON DUPLICATE KEY UPDATE後面使用VALUES指的就是插入的記錄的值,而不使用VALUES指的是表的自身值。




注意: ON DUPLICATE KEY UPDATE的後面執行的UPDATE更新的記錄是WHERE重複的主鍵或者惟一鍵的ID,這點很是重要。


好比下面這種狀況:


INSERT INTO Tupdate() VALUES(1,1),(2,1) ON DUPLICATE KEY UPDATE NAME1=VALUES(ID)+1;


它是惟一鍵NAME1重複可是主鍵不重複,執行的語句是這樣的:


INSERT INTO Tupdate() VALUES(1,1)

UPDATE Tupdate

SET NAME1=2+1

WHERE ID=1;




不要認爲會插入主鍵ID=2的記錄進去。


總結


上面的三種處理重複值的方法都支持標準的INSERT語法,包括INSERT INTO...VALUES, INSERT INTO ....SET ,INSERT INTO..... SELECT。



回頭須要了,再來翻翻!

相關文章
相關標籤/搜索