mysql数据保存时若数据已存在则更新或者忽略

本文介绍了在数据库操作中如何处理数据已存在的情况。当数据存在时,可以使用`REPLACE INTO`来更新数据,它会先删除已有行再插入新数据;而`INSERT IGNORE`则会忽略重复数据,只在数据库中不存在时插入新记录。关键在于确保用于判断重复的字段具有主键或唯一索引。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

数据保存时若数据已存在则更新或者忽略

  • 数据存在则更新
    --插入替换数据
    --首先尝试插入数据到表中,如果发现表中已经有此行数据(根据主键或者唯一索引判断)
    --则先删除此行数据,然后插入新的数据。否则,直接插入新数据
    REPLACE INTO 表名(字段1, 字段2, ...) VALUES(1,2, ...);
    
  • 数据存在则忽略
    --会忽略数据库中已经存在的数据,如果数据库没有数据,就插入新的数据,
    --如果有数据的话就跳过这条数据
    INSERT IGNORE 表名(字段1, 字段2, ...) VALUES(1,2, ...);
    
  • 说明
    实现数据更新或忽略的判别字段必须是主键或唯一索引(可以是单列或多列)。
    比如要根据id判断是否重复,那么id必须是主键或者存在唯一索引。
    比如要根据id + cardNo判断是否重复,那么要建立2个字段联合的唯一索引。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

古口古

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值