MySQL中插入数据,如果插入的数据在表中已经存在(主键或者唯一键已存在),使用insert ignore 语法可以忽略插入重复的数据。
CREATE TABLE `users` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL,
`email` varchar(64) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL,
`password` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `users_email_unique` (`email`),
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
插入数据
INSERT INTO users ( name, email, `password` ) VALUES ( 'gan', '123@com', 1 ),( 'gan', '123@456.com', 1 );
因为email=‘123@com’已存在,所以报错
INSERT INTO users ( NAME, email,
password
) VALUES ( ‘gan’, ‘123@com’, 1 ),( ‘gan’, ‘123@com’, 1 )
1062 - Duplicate entry ‘123@com’ for key ‘users_email_unique’
时间: 0.014s
INSERT INTO:跳过重复行,插入其余
增加IGNORE
,执行成功(直接跳过已存在的数据)
INSERT IGNORE INTO users ( name, email, `password` ) VALUES ( 'gan', '123@com', 1 ),( 'gan', '123@456.com', 1 );
如果业务逻辑需要插入重复数据时自动忽略,不妨试试MySQL 的 insert ignore 功能。
REPLACEINTO:删除重复行,重新插入
REPLACE INTO users ( name, email, `password` ) VALUES ( 'gan1', '123@com', 1 ),( 'gan2', '123@456.com', 2 );
影响行数为什么是4行。插入第一行时发现已存在,故删除已存在数据,再插入;插入第一行时发现已存在,故删除已存在数据,再插入。删除两行,插入两行。