MySQL主键冲突时的更新操作和替换操作在功能上有什么差别(如图)
曾经蜡笔没有小新
曾经蜡笔没有小新 2017-06-07 09:25:03
0
2
889

曾经蜡笔没有小新
曾经蜡笔没有小新

全部回复(2)
世界只因有你

INSERT ... ON DUPLICATE KEY UPDATEREPLACE是有区别的,前者INSERT失败后执行UPDATE,后者相当于DELETE再INSERT,原来整行都消失哦!

具体而言,如果你的表有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 判断如果有重复的话,先进行删除操作,再进行插入操作

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板