MySQL中insert ignore into, replace into, on duplicate key update的用法

本文详细介绍了MySQL中的INSERT IGNORE和REPLACE INTO语句的用法。INSERT IGNORE在遇到重复键或非空错误时会忽略错误并可能赋予默认值。而REPLACE INTO则会先删除重复的记录再插入新的,如果主键是自增的,自增主键会递增。这两种方式在处理数据冲突时有不同的策略。
摘要由CSDN通过智能技术生成

1、insert ignore into

ignore不仅会忽略duplicate key(重复primary或者unique)错误,还会忽略非空错误,如果插入语句没有给予非空字段值,则会给默认值,int类型默认0,varchar默认‘’ 空字符串,此时,可以使用on duplicate key value(MySQL中特有的语法),当主键或唯一索引重复时,执行后面的update,例如:phone是唯一索引

insert into student(name, age, phone) values('风云',25, 345)on duplicate key update phone= phone;

2.replace into

如果存在primary or unique相同的记录,则先删除掉。再插入新记录。如果记录有多个字段,在插入的时候如果有的字段没有赋值,那么新插入的记录这些字段为空。

REPLACE INTO books SELECT 1, 'MySQL Manual' FROM books

 对表进行replace into操作的时候,
   当不存在冲突时,replace into 相当于insert操作。 
   当存在pk冲突的时候是先delete再insert,如果主键是自增的,则自增主键会做 +1 操作。
   当存在uk冲突的时候是直接update。,如果主键是自增的,则自增主键会做 +1 操作。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值