扫码关注官方订阅号
INSERT ... ON DUPLICATE KEY UPDATE和REPLACE是有区别的,前者INSERT失败后执行UPDATE,后者相当于DELETE再INSERT,原来整行都消失哦!
INSERT ... ON DUPLICATE KEY UPDATE
REPLACE
具体而言,如果你的表有3列的话:
id name alias 1 王五 王二麻子
这两句的效果是不一样的:
INSERT INTO pri (id, name) VALUES (1, '李四') ON DUPLICATE KEY UPDATE name = '李四' REPLACE INTO pri (id, name) VALUES (1, '李四')
前者alias没变,后者却会变成null。
insert into on duplicate update 是在原纪录上进行操作replace 判断如果有重复的话,先进行删除操作,再进行插入操作
微信扫码关注PHP中文网服务号
QQ扫码加入技术交流群
扫描下载App
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
PHP学习
技术支持
返回顶部
INSERT ... ON DUPLICATE KEY UPDATE
和REPLACE
是有区别的,前者INSERT失败后执行UPDATE,后者相当于DELETE再INSERT,原来整行都消失哦!具体而言,如果你的表有3列的话:
这两句的效果是不一样的:
前者alias没变,后者却会变成null。
insert into on duplicate update 是在原纪录上进行操作
replace 判断如果有重复的话,先进行删除操作,再进行插入操作