文章详情页
MySQL主键冲突时的更新操作和替换操作在功能上有什么差别(如图)
浏览:226日期: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. html5 - 在一个页面中 初始了两个swiper 不知道哪里错了 一直不对2. javascript - 如何将 windows 下编辑器中的 CRLF 替换为 LF?3. javamail发送邮件是否跟所在的网络环境有关?4. javascript - 求解答:实例对象调用constructor,此时constructor内的this的指向?5. Windows系统能否利用Docker使用Ubuntu吗?Ubuntu能使用本机的显卡吗?6. 请教,关于python字典,合并相同值的键的实现方法7. mysql5.7就没有官方性质的详细配置文件吗?求大神告知8. android - 京东移动端网页和其app加载的url所做的呈现不应该是完全一样的吗?9. css3中translate(-50%,-50%)对 transform-origin的奇葩影响?10. python的MySQLdb库中的executemany方法如何改变默认加上的单引号?
排行榜

网公网安备