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

  • 相关阅读:
    为什么运营Youtube要用住宅ISP代理?
    Cocos2dx-lua ScrollView[一]基础篇
    编程面试_动态规划
    ​​植物大战僵尸杂交版直装版v2.1 安卓版:全新策略塔防体验
    Spring 6.x 的 AoT 相关支持的注解
    分布式架构下如何选择最佳 Store?
    SpringBoot整合阿里云OSS对象存储
    tcpdump进行IP抓包
    Docker的自定义镜像
    无线渗透实操_AIRCRACK-NG基础
  • 原文地址:https://blog.csdn.net/Gan_1314/article/details/125911362