• 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;
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    插入数据

    INSERT INTO users ( name, email, `password` ) VALUES ( 'gan', '123@com', 1 ),( 'gan', '123@456.com', 1 );
    
    • 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 );
    
    • 1

    如果业务逻辑需要插入重复数据时自动忽略,不妨试试MySQL 的 insert ignore 功能。

    REPLACEINTO:删除重复行,重新插入

    REPLACE INTO users ( name, email, `password` ) VALUES ( 'gan1', '123@com', 1 ),( 'gan2', '123@456.com', 2 );
    
    • 1

    在这里插入图片描述

    影响行数为什么是4行。插入第一行时发现已存在,故删除已存在数据,再插入;插入第一行时发现已存在,故删除已存在数据,再插入。删除两行,插入两行。

  • 相关阅读:
    MySQL的事务和存储引擎
    如何撰写有效的公司新闻稿?实用指南
    web share api 分享
    Go中的逻辑处理(if,switch),for循环
    Java扩展Nginx之六:两大filter
    java计算机毕业设计ssm党支部在线学习
    【Kotlin 协程】协程底层实现 ② ( 协程调度器 | 协程任务泄漏 | 结构化并发 )
    公网远程访问本地Jupyter Notebook服务
    360 度评估问题示范
    Vue3.X笔记总结
  • 原文地址:https://blog.csdn.net/Gan_1314/article/details/125911362