Replace into 与Insert into on duplicate key update的区别

时间:2023-03-09 16:29:12
Replace into 与Insert into on duplicate key update的区别

前提条件:除非表有一个PRIMARY KEY或UNIQUE索引,否则,使用这2条语句没有意义。该语句会与INSERT相同

1. Replace into

(1)   添加相同的主键

操作前                                      操作后

Replace into 与Insert into on duplicate key update的区别

当主键冲突时, 先删除重复主键的记录,然后插入一条新记录,replace覆盖相关字段,其它字段填充默认值

(2)   添加相同的UNIQUE字段

操作前                                   操作后

Replace into 与Insert into on duplicate key update的区别

当UNIQUE字段冲突时, 先删除重复key的记录,然后插入一条新记录,replace覆盖相关字段,其它字段填充默认值

(3)  添加不重复的数据

操作前                                        操作后

Replace into 与Insert into on duplicate key update的区别

当添加不重复的数据时,正常添加语句

2.Insert into ..... on duplicate key update

(1)  添加相同的主键

操作前                                            操作后

Replace into 与Insert into on duplicate key update的区别

当主键冲突时,只执行后面的update操作语句

(2) 添加相同的UNIQUE字段

操作前                                        操作后

Replace into 与Insert into on duplicate key update的区别

当UNIQUE字段冲突时,只执行后面的update操作语句

(3)  添加不重复的数据

操作前                                      操作后

Replace into 与Insert into on duplicate key update的区别

当添加不重复的数据时,只执行insert操作语句

总结:

  1. 相同之处
    (1)添加不重复的数据时,replace insert与insert .. on deplicate udpate相同。
  2. 不同之处(重复的主键 或 重复的UNIQUE字段)
    (1)replace insert是先删除重复的记录,然后插入一条新记录,这个时候,如果replace语句的字段不全的话,有些原有字段的值会被自动填充为默认值。
    (2)insert .. deplicate update只执行update之后的语句。
  3. 从底层执行效率上来讲,replace要比insert .. on deplicate update效率要高,但是在写replace的时候,字段要写全,防止老的字段数据被删除。