首页 > 技术文章 > MySQL:INSERT ... UPDATE

fxyy 2017-11-23 17:17 原文

在 INSERT 语句末尾指定ON DUPLICATE KEY UPDATE时,如果插入的数据会导致表中的 UNIQUE 索引或 PRIMARY KEY 出现重复值,则会对导致重复的数据执行 UPDATE 操作;如果不会导致重复,则执行 INSERT 操作。

例如,表中有 id,f1,f2 三个字段,其中 id 为主键。执行语句:

INSERT INTO test1(id, f1, f2) VALUES(1, 2, 3) ON DUPLICATE KEY UPDATE f1=VALUES(f1), f2=VALUES(f2);

如果插入数据导致主键 id 重复,则在重复的主键上更新 f1,f2 字段;如果不会导致重复,直接插入数据。如果不会导致重复,直接插入数据。 在执行多条数据的插入时,亦可使用此语句。

注意:

  1. ON DUPLICATE KEY UPDATE 是 MySQL 的特有语法,并不是 SQL 标准语法。

  2. 此语句在执行 INSERT 操作时,受影响行数为 1。执行 UPDATE 操作时,受影响行数为 2。

推荐阅读