文章詳情頁
MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)
瀏覽:176日期: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. angular.js - 求問大神?angularjs加載外部的html模板。有閃動如何解決2. angular.js - 三大框架react、vue、angular的分析3. mysql - 怎么生成這個sql表?4. 隨機產生200個小寫英文字母,并統計個數,這是在網上看到的粒子,我想問怎樣把它變得更簡便?5. node.js - vue-resource,如何改變響應格式?6. mysql - 把一個表中的數據count更新到另一個表里?7. javascript - 百度地圖自己的產品可以精確定位,為什么我調用他的公開API卻必須經過用戶同意才能獲取精確定位,而且還慢?8. 如何消除css3斜切角引起的毛邊問題9. windows10 - mysql時區問題10. javascript - react+百度地圖
排行榜
