MySql插入一条记录,结果提示主键冲突,怎么办?git
批量插入数据时,发现插入的这批数据中,有某些记录存在惟一键冲突,一个一个跳出来就比较麻烦了,有什么好的办法直接忽略掉冲突的记录么?github
下面简单记录三种处理方式sql
<!-- more -->学习
某些场景下,咱们须要批量插入的数据,某些已经在DB中了,所以我但愿在出现冲突时,直接跳过,把能插入的都插入就好,这种状况下,使用ignore关键词就比较合适了spa
一个实际的case以下code
insert ignore into table (xxx, xxx) values (xxx,xxx), (xxx, xxx);
执行截图以下, 注意下面红框中的内容,表示忽略了两条,执行插入成功一条blog
若是在批量插入中,存在冲突时,我但愿用个人新数据替换旧的数据,这个时候就可使用replace into
了rem
经常使用姿式以下get
replace into `user` (`id`, `name`, `create_at`, `update_at`) values (1, 'test', '2018-07-10 18:54:00', '2018-07-10 19:54:52'), (2, 'test2', '2018-07-10 18:54:00', '2018-07-10 19:54:52'), (3, 'test3', '2018-07-10 18:54:00', '2018-07-10 19:54:52');
执行截图以下,注意红框中,当某条记录冲突以后并修改,则影响行数为2, 其实际过程是博客
在出现冲突时,但愿更新某些数据,这个时候就能够在insert语句的最后加上on duplicate key update
了
实例以下
insert into `user` (`id`, `name`, `create_at`, `update_at`) values (1, 'test0', '2018-07-10 18:54:00', '2018-07-10 18:54:52') ON DUPLICATE KEY UPDATE `update_at`='2018-07-10 19:58:05';
执行截图以下,这个是在原记录的基础上执行更新指定的value, 好比上面的插入中,当冲突时,咱们只更新update_at
字段,而name的test0
没有更新
一灰灰的我的博客,记录全部学习和工做中的博文,欢迎你们前去逛逛
尽信书则不如,已上内容,纯属一家之言,因我的能力有限,不免有疏漏和错误之处,如发现bug或者有更好的建议,欢迎批评指正,不吝感激