文章详情页
MySQL主键冲突时的更新操作和替换操作在功能上有什么差别(如图)
浏览:198日期: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. python - 求一个在def中可以实现调用本def满足特定条件continue效果的方法(标题说不太清楚,请见题内描述)2. $fields = $values = [];这条代码一直定义不了,一直报错,老师的源码也是被报错的,执行不了,请问该怎么解决这个问题3. USE关键字4. javascript - mysql插入数据时怎样避免与库中的数据重复?5. MySQL 如何 SELECT 除去某一列的所有列?6. 导入phpmyadmin的时候报错了7. MySQL能否给某个字段的值设置有效期?8. 求一个mySQL安装包9. mysql数据库做关联一般用id还是用户名10. MySQL 这句 创建表结构语句的错误在哪?
排行榜
