INSERT IGNORE用于跳过重复主键或唯一索引冲突,避免插入错误。示例中向users表插入重复id和name时,第二条记录被忽略而不报错。适用于批量导入、初始化配置等场景,但不更新原有数据,且可能忽略外键错误。与REPLACE INTO(删除后插入)和ON DUPLICATE KEY UPDATE(冲突时更新)不同,INSERT IGNORE仅跳过冲突行。可通过批量插入多值、结合LOAD DATA INFILE提升效率,并用ROW_COUNT()判断实际插入行数。

在 MySQL 中,INSERT IGNORE 是一个非常实用的语句,用于在插入数据时忽略某些错误,避免程序中断。它主要适用于防止因重复主键或唯一索引冲突而导致的插入失败。
INSERT IGNORE 的基本用法
当你执行 INSERT 语句时,如果目标表中已存在相同主键或唯一键的数据,默认会抛出错误。使用 INSERT IGNORE 可以让 MySQL 忽略这些错误,跳过冲突的记录继续执行。
示例:假设有一张用户表:
CREATE TABLE users (
id INT PRIMARY KEY,
name VARCHAR(50) UNIQUE
);
尝试插入重复数据:
INSERT IGNORE INTO users (id, name) VALUES (1, 'Alice'); INSERT IGNORE INTO users (id, name) VALUES (1, 'Alice'); -- 忽略重复
第二条语句不会报错,也不会更新原有数据,只是被“安静地”忽略。
适用场景与注意事项
INSERT IGNORE 在以下情况特别有用:
- 批量导入数据时,避免因个别重复记录导致整个操作失败
- 初始化配置表,确保某些默认数据只插入一次
- 与其他系统对接时容错处理重复数据
但要注意:
- 它不会更新已有数据,仅跳过冲突行
- 除了唯一键冲突,也会忽略外键约束错误(取决于存储引擎)
- 某些警告仍可能产生,可通过 SHOW WARNINGS 查看
- INSERT IGNORE:冲突时跳过,不插入也不修改
- REPLACE INTO:冲突时先删除旧记录,再插入新记录(可能导致自增 ID 变化)
- INSERT ... ON DUPLICATE KEY UPDATE:冲突时执行更新操作,更灵活
与 REPLACE INTO 和 ON DUPLICATE KEY UPDATE 的区别
这三个语句都用于处理插入冲突,但行为不同:
例如,想更新已有用户的姓名:
INSERT INTO users (id, name) VALUES (1, 'Alice') ON DUPLICATE KEY UPDATE name = 'Alice';
提高效率的小技巧
使用 INSERT IGNORE 时可以结合以下方式提升性能和可控性:
- 批量插入多个值,减少语句执行次数:
INSERT IGNORE INTO table VALUES (1,'a'), (2,'b'), (3,'c'); - 配合 LOAD DATA INFILE 使用,导入大文件时避免重复报错
- 在应用层判断是否真正插入了数据,可通过 ROW_COUNT() 获取实际影响行数(注意:被忽略的行返回影响 0 行)
基本上就这些。INSERT IGNORE 是个简单但强大的工具,适合“只插不改”的场景,合理使用能显著提升数据操作的稳定性。










