MySQL插入数据insert ignore和replace into

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行。插入第一行时发现已存在,故删除已存在数据,再插入;插入第一行时发现已存在,故删除已存在数据,再插入。删除两行,插入两行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值