文章詳情頁
MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)
瀏覽:138日期:2022-06-11 15:47:52
問題描述
問題解答
回答1:INSERT ... ON DUPLICATE KEY UPDATE和REPLACE是有區別的,前者INSERT失敗后執行UPDATE,后者相當于DELETE再INSERT,原來整行都消失哦!
具體而言,如果你的表有3列的話:
id name alias1 王五 王二麻子
這兩句的效果是不一樣的:
INSERT INTO pri (id, name) VALUES (1, ’李四’) ON DUPLICATE KEY UPDATE name = ’李四’REPLACE INTO pri (id, name) VALUES (1, ’李四’)
前者alias沒變,后者卻會變成null。
回答2:insert into on duplicate update 是在原紀錄上進行操作replace 判斷如果有重復的話,先進行刪除操作,再進行插入操作
相關文章:
1. android - 分享到微信,如何快速轉換成字節數組2. angular.js - Beego 與 AngularJS的模板格式沖突,該怎么解決?3. javascript - 能否讓vue-cli的express修改express重啟服務4. 解決Android webview設置cookie和cookie丟失的問題5. node.js - npm一直提示proxy有問題6. phpstorm 沒有安裝Emmet怎么還有Emmet的相關功能啊7. python - flask template file not found8. mysql怎么多表刪除啊?9. javascript - 有沒有iOS微信中可以在背景播放視頻的方法?10. python - 網頁title中包含換行,如何用正則表達式提取出來?
排行榜
