文章詳情頁
mysql - INSERT ON DUPLICATE KEY 是如何判斷重復key的?
瀏覽:112日期:2022-06-14 18:52:24
問題描述
使用INSERT的時候 有表T(id,A,B,C,D)
插入的時候希望通過A,B索引唯一記錄 ,有重復的時候更新C,D
INSERT INTO T(A,B,C,D) VALUES (a,b,c,d) ON DUPLICATE KEY UPDATE C=C+1,D=d 居然是可用的
INSERT 和UPDATE都是正常的
只是不知道有沒有其他問題
所以 MySQL到底是如何判斷DUPLICATE KEY的?
問題解答
回答1:這條語句相當于:
INSERT INTO ... VALUES ...
當INSERT(因為主鍵或唯一鍵沖突)失敗時,執行
UPDATE ... SET ... WHERE A = a AND B = b
只是這個過程用一個原子語句來實現罷了,具體可參閱MySQL的官方文檔: https://dev.mysql.com/doc/ref...
如果表中有多個唯一鍵,情況就更復雜了,有興趣可以深入研究。還有一個類似的語句叫 REPLACE 跟INSERT ... ON DUPLICATE KEY UPDATE作用類似,但原理是不一樣的,有興趣可參閱: https://dev.mysql.com/doc/ref...
相關文章:
1. Python爬蟲如何爬取span和span中間的內容并分別存入字典里?2. css3 - 微信前端頁面遇到的transition過渡動畫的bug3. javascript - 請教如何獲取百度貼吧新增的兩個加密參數4. python - 編碼問題求助5. python - 關于計算日期的問題6. (python)關于如何做到按win+R再輸入文件文件名就可以運行?7. Python如何播放還存在StringIO中的MP3?8. mysql - 分庫分表、分區、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處9. mysql 一個sql 返回多個總數10. mysql - 如何減少使用或者不用LEFT JOIN查詢?
排行榜
