欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 运维知识 > 数据库 >内容正文

数据库

MySQL replace into (insert into 的增强版)

发布时间:2025/3/8 数据库 62 豆豆
生活随笔 收集整理的这篇文章主要介绍了 MySQL replace into (insert into 的增强版) 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

在使用SQL语句进行数据表插入insert操作时,如果表中定义了主键,插入具有相同主键的记录会报错:

   Error Code: 1062. Duplicate entry 'XXXXX' for key 'PRIMARY'(主键冲突)

  这样我们只好检查主键是不是存在,若存在则更新,若不存在则插入。或者写SQL流程控制语句(if...else...)

 

Mysql提供了replace into跟insert into的功能一样。不同点在于:

  如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。否则,直接插入新数据。

  注意:因为要根据主键或者是唯一索引判断是否有重复数据,所以操作的表必须要有主键或者是唯一索引。否则的话,replace into 会直接插入数据。

 

Mysql replace into用法有三种,最简单的一种用法就是直接将 "insert" 关键字替换为"replace"就可以啦。

  insert into t(... , ...) values(... , ...)

   修改为

  replace into t(... , ...) values(... , ...)

总结

以上是生活随笔为你收集整理的MySQL replace into (insert into 的增强版)的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。