文章詳情頁
MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)
瀏覽:240日期: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 hub上有些鏡像的tag被標記““This image has vulnerabilities””2. docker-compose中volumes的問題3. boot2docker無法啟動4. nignx - docker內nginx 80端口被占用5. docker安裝后出現Cannot connect to the Docker daemon.6. docker容器呢SSH為什么連不通呢?7. node.js - antdesign怎么集合react-redux對input控件進行初始化賦值8. dockerfile - 為什么docker容器啟動不了?9. java - SSH框架中寫分頁時service層中不能注入分頁類10. 關于docker下的nginx壓力測試
排行榜

網公網安備