• 180710-MySql插入唯一键冲突的三种可选方式


    logo

    MySql插入时唯一键冲突的几种处理方式

    MySql插入一条记录,结果提示主键冲突,怎么办?

    批量插入数据时,发现插入的这批数据中,有某些记录存在唯一键冲突,一个一个跳出来就比较麻烦了,有什么好的办法直接忽略掉冲突的记录么?

    下面简单记录三种处理方式

    I. 插入时唯一键冲突问题

    1. Ignore关键词

    某些场景下,我们需要批量插入的数据,某些已经在DB中了,因此我希望在出现冲突时,直接跳过,把能插入的都插入就好,这种情况下,使用ignore关键词就比较合适了

    一个实际的case如下

    insert ignore into table (xxx, xxx) values (xxx,xxx), (xxx, xxx);
    

    执行截图如下, 注意下面红框中的内容,表示忽略了两条,执行插入成功一条

    image.png

    2. Replace Into方式

    如果在批量插入中,存在冲突时,我希望用我的新数据替换旧的数据,这个时候就可以使用replace into

    常用姿势如下

    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, 其实际过程是

    • 删除冲突数据
    • 插入新的数据

    image.png

    3. ON DUPLICATE KEY UPDATE

    在出现冲突时,希望更新某些数据,这个时候就可以在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没有更新

    image.png

    II. 其他

    1. 一灰灰Bloghttps://liuyueyi.github.io/hexblog

    一灰灰的个人博客,记录所有学习和工作中的博文,欢迎大家前去逛逛

    2. 声明

    尽信书则不如,已上内容,纯属一家之言,因个人能力有限,难免有疏漏和错误之处,如发现bug或者有更好的建议,欢迎批评指正,不吝感激

    3. 扫描关注

    QrCode

  • 相关阅读:
  • 原文地址:https://www.cnblogs.com/yihuihui/p/9291235.html
  • 最新文章
  • 热门文章
一二三 - 开发者的网上家园