文章详情页
MySQL主键冲突时的更新操作和替换操作在功能上有什么差别(如图)
浏览:203日期: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. 在windows下安装docker Toolbox 启动Docker Quickstart Terminal 失败!2. web - nginx location 搜索算法问题!?3. docker-machine添加一个已有的docker主机问题4. 关于docker下的nginx压力测试5. Docker for Mac 创建的dnsmasq容器连不上/不工作的问题6. angular.js - angular内容过长展开收起效果7. debian - docker依赖的aufs-tools源码哪里可以找到啊?8. docker - 如何修改运行中容器的配置9. docker安装后出现Cannot connect to the Docker daemon.10. docker - 各位电脑上有多少个容器啊?容器一多,自己都搞混了,咋办呢?
排行榜

网公网安备