insert into -- 表示插入数据,数据库会检查主键,如果出现重复会报错; replace into -- 表示插入替换数据,需求表中有PrimaryKey,或者unique索引,如果数据库已经存在数据,则用新数据替换,如果没有数据效果则和insert into一样; insert ignore -- 表示如果中已经存在相同的记录,则忽略当前新数据;不存在则插入;
插入重复数据时更新
第一种方法:使用语句实现
示例一:插入多条记录
1 2 3 4 5 6 7 8 9 10 11 12
-- 假设有一个主键为 client_id 的 clients 表,可以使用下面的语句: INSERT INTO clients(client_id,client_name,client_type) SELECT supplier_id,supplier_name,'advertising' FROM suppliers WHERE not exists(select * from clients where clients.client_id=suppliers.supplier_id);
-- 示例一:插入单条记录 INSERT INTO clients(client_id,client_name,client_type) SELECT 10345,'IBM','advertising' FROM dual WHERE not exists (select * from clients where clients.client_id=10345); -- 使用 dual 做表名可以让你在 select 语句后面直接跟上要插入字段的值,即使这些值还不存在当前表中。
-- 如果 a 为主键或者为UNIQUE索引,则下面两条sql有相同作用 -- 如果行作为新记录被插入,则受影响行的值为1;如果原有的记录被更新,则受影响行的值为2。 INSERT INTO table (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=c+1; UPDATE table SET c=c+1 WHERE a=1;
-- 注释:如果列b也是唯一列,则INSERT与此UPDATE语句相当 -- 如果a=1 OR b=2与多个行向匹配,则只有一个行被更新。通常,您应该尽量避免对带有多个唯一关键字的表使用ON DUPLICATE KEY子句。 UPDATE table SET c=c+1 WHERE a=1 OR b=2 LIMIT 1;
-- 可以在UPDATE子句中使用VALUES(col_name)函数从INSERT…UPDATE语句的INSERT部分引用列值。换句话说,如果没有发生重复关键字冲突,则UPDATE子句中的VALUES(col_name)可以引用被插入的col_name的值。本函数特别适用于多行插入。VALUES()函数只在INSERT…UPDATE语句中有意义,其它时候会返回NULL。 INSERT INTO table (a,b,c) VALUES (1,2,3),(4,5,6) ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b);
-- 本语句与以下两个语句作用相同 INSERT INTO table (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=3; INSERT INTO table (a,b,c) VALUES (4,5,6) ON DUPLICATE KEY UPDATE c=9;