文章詳情頁
MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)
瀏覽:152日期: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. docker - 如何修改運行中容器的配置2. javascript - Web微信聊天輸入框解決方案3. 請教各位大佬,瀏覽器點 提交實例為什么沒有反應4. docker images顯示的鏡像過多,狗眼被亮瞎了,怎么辦?5. javascript - 為什么form表單提交沒有跨域問題,但ajax提交有跨域問題?6. javascript - Ajax加載Json時,移動端頁面向左上角縮小一截兒,加載完成后才正常顯示,這該如何解決?7. javascript - history.replaceState()無法改變query參數8. javascript - 移動端textarea不能上下滑動,該怎么解決?9. javascript - 關于audio標簽暫停的問題10. javascript - 音頻加載問題
排行榜
