文章详情页
MySQL主键冲突时的更新操作和替换操作在功能上有什么差别(如图)
浏览:272日期: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. javascript - 微信小程序 如何实现这种左滑动出现删除的办法?有相关api吗?2. python打开.py文件的时候出现window无法打开该文件是怎么回事呢?3. javascript - vue中input的blur影响了下拉的点击事件如何解决4. docker gitlab 如何git clone?5. javascript - swiper插件loop模式下的BUG?6. dockerfile - 为什么docker容器启动不了?7. docker 17.03 怎么配置 registry mirror ?8. mysql插入文本如果是个sql语句就报错了9. 关docker hub上有些镜像的tag被标记““This image has vulnerabilities””10. javascript - sublime快键键问题
排行榜

网公网安备