MySQL的REPLACE INTO和ON DUPLICATE KEY UPDATE区别
REPLACE INTO
用法示例:
REPLACE INTO tablename (f1, f2, f3) VALUES(vf1, vf2, vf3), (vvf1, vvf2, vvf3);
ON DUPLICATE KEY UPDATE
用法示例:
INSERT INTO tablename (a,b,c) VALUES (1,2,3), (4,5,6)
ON DUPLICATE KEY UPDATE c = VALUES(c);
如果没有主键或唯一索引冲突,两者效果都是 INSERT
插入数据,如果存在冲突,那么
-
REPLACE INTO
是先DELETE
再INSERT
-
ON DUPLICATE KEY UPDATE
是只执行其后的UPDATE
语句。
如果想要实现插入或更新效果,选择 ON DUPLICATE KEY UPDATE
比 REPLACE INTO
性能更好,表现更佳。
版权声明:凡未经本网站书面授权,任何媒体、网站及个人不得转载、复制、重制、改动、展示或使用本网站的局部或全部的内容或服务,或在非本网站所属服务器上建立镜像。如果已转载,请自行删除。同时,我们保留进一步追究相关行为主体的法律责任的权利。我们希望与各媒体合作,签订著作权有偿使用许可合同,故转载方须书面/邮件申请,以待商榷。