开发者社区 > 数据库 > 正文

您好,请问rds mysql数据库如果主键冲突插入的话会报错还是更新相同数据呢?

您好,请问rds mysql数据库如果主键冲突插入的话会报错还是更新相同数据呢?

展开
收起
真的很搞笑 2023-05-16 18:10:02 1149 0
3 条回答
写回答
取消 提交回答
  • 公众号:网络技术联盟站,InfoQ签约作者,阿里云社区签约作者,华为云 云享专家,BOSS直聘 创作王者,腾讯课堂创作领航员,博客+论坛:https://www.wljslmz.cn,工程师导航:https://www.wljslmz.com

    如果在阿里云 RDS MySQL 数据库中插入数据时发生主键冲突,会报错,如下所示:

    ERROR 1062 (23000): Duplicate entry 'xxx' for key 'PRIMARY'
    

    如果您需要更新相同主键的数据,可以使用 ON DUPLICATE KEY UPDATE 语句进行处理。这个语句可以在插入数据时检测到主键冲突,然后更新相应的记录。例如:

    INSERT INTO 表名 (列1, 列2, 列3)
    VALUES (值1, 值2, 值3)
    ON DUPLICATE KEY UPDATE 列2=值2, 列3=值3;
    

    这个语句将会尝试插入新的数据,如果主键冲突就更新相应的列。这并不会自动删除相应重复数据,您需要手动进行删除。

    2023-05-23 14:17:38
    赞同 展开评论 打赏
  • 值得去的地方都没有捷径

    如果在RDS MySQL数据库中插入数据时出现主键冲突,这会导致插入操作失败,并返回一个错误。这是因为主键是用于唯一标识每个表中的每一行数据的,因此不能插入主键已经存在的数据。

    更新相同数据通常是使用UPDATE语句来完成的,如果主键已经存在,则使用INSERT操作将失败,不会更新相同数据。如果您希望插入或者更新数据,可以考虑使用INSERT INTO ... ON DUPLICATE KEY UPDATE语句,这将在出现主键冲突时更新数据而不是插入新数据,以确保主键保持唯一性。

    2023-05-22 10:13:29
    赞同 展开评论 打赏
  • 如果是insert,会报错。 replace into 会忽略报错,删除原数据,重新insert。 ingore会直接忽略,不对原有数据进行操作,直接插入一条新的数据,此回答整理自钉群“阿里云DMS数据管理用户交流群”

    2023-05-16 18:14:56
    赞同 展开评论 打赏

数据库领域前沿技术分享与交流

相关产品

  • 云数据库 RDS MySQL 版
  • 相关电子书

    更多
    搭建电商项目架构连接MySQL 立即下载
    搭建4层电商项目架构,实战连接MySQL 立即下载
    PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

    相关镜像