2015年5月18日 星期一

[野人獻曝] 千萬不要在 MySQL 內有用到 auto_increment 的表下 INSERT ... ON DUPLICATE

原因很可怕,所以不要問!

最近開了一個有 auto_increment 欄位的資料表,
並且將該表中幾個欄位設為唯一值索引,
然後就下了以下的SQL塞資料:
INSERT INTO EXAMPLE (a, b, c) VALUES ('1', '2', '3') ON DUPLICATE KEY UPDATE d = '4'
結果發現 auto_increment 欄位中的值越變越大,
不過一千多筆的資料,流水號卻取到七萬多。

看了 MySQL 的說明
才發現下 INSERT ... ON DUPLICATE KEY 時碰到 auto_increment 欄位時,
流水號也會持續增加(只有 Update 時才不會增加),
所以下一次真的有新增資料時,流水號會跳得老遠去......

當下只好照 StackOverflow 上的一篇回覆修改程式碼解決這個不算大卻有點微妙的問題......
張貼留言