`
jjhpeopl
  • 浏览: 108788 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

mysql的replace into“坑”

阅读更多
在向表中插入数据的时候,经常遇到这样的情况:1. 首先判断数据是否存在; 2. 如果不存在,则插入;3.如果存在,则更新。
 
这种情况就可以使用replace into语句来解决,但是有没有问题,且看下去
 
下面是数据更新前的样子

在auto这个表中,k字段是唯一索引,当执行replace into auto (k,v) values (10,11);后,数据变为
 

 
 从图中可以看到,id=10的那条记录没有了,新增加了一条id=23的记录,而且k,v的值正好是咱们刚想更新的值
 
再执行一个语句replace into auto (k,v) values (9,9);观察结果如下
 
这次是真的增加了一条id=24的记录,而其他记录没有任何变化。
 
通过以上操作可以看出replace into执行的逻辑
1、遇到PRIMARY KEY或UNIQUE索引的,新记录与旧记录有冲突的(这里实际产生了异常duplicate key error),会把旧记录删除,然后再插入新记录
2、若是新记录没有冲突,就直接插入一条新记录,与insert into一样
 
看起来很正常,这里针对第一种逻辑会有问题
1、把旧记录删除之后,插入的新记录只是插入了那些指定的字段,原本不想更新的字段,直接为默认值了,会导致数据丢失
2、若旧记录的id跟其他表是有关联的,更新后新记录会产生新的id,导致这种关联丢失
3、而且使用replace into会导致自增主键id一直增大,很容易导致id值范围不够用
另外,若是数据库存在主从关系,在主机器上进行了replace into操作之后,从机器上对应表的AUTO_INCREMENT是不会更新的,导致从机器转为主机器时,新插入数据会出现异常,直到AUTO_INCREMENT增加到原来主机器的值为止。 
  • 大小: 32.1 KB
  • 大小: 60.6 KB
  • 大小: 86.4 KB
0
0
分享到:
评论

相关推荐

    MySQL replace into 用法.txt

    MySQL replace into 用法.txt

    Mysql中replace与replace into的用法讲解

    Mysql replace与replace into都是经常会用到的功能;replace其实是做了一次update操作,而不是先delete再insert;而replace into其实与insert into很相像,但对于replace into,假如表中的一个旧记录与一个用于...

    MySQL replace into 语句浅析(一)

    主要介绍了MySQL replace into 语句浅析(一),本文讲解了replace into的原理、使用方法及使用的场景和使用示例,需要的朋友可以参考下

    浅析MySQL replace into 的用法

    在 SQL Server 中可以这样处理: 代码如下: if not exists (select 1 from t where id = 1) ...MySQL 中有更简单的方法: replace into 代码如下: replace into t(id, update_time) values(1, now());或 repl

    mysql中replace into的用法详解

    replace into语句会根据唯一键/主键删除原有的一条记录, 并且插入一条新的记录来替换原记录。如果没有表不存在唯一键/主键 或者 插入的数据唯一键/主键没有重复的,那么会新增一条记录。 新建一个test表,三个字段...

    mysql 的replace into实例详解

    mysql 的replace into实例详解 replace into 跟 insert 功能类似,不同点在于:replace into 首先尝试插入数据到表中。 1、如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的...

    MySQL Replace INTO的使用

    REPLACE的运行与INSERT很相像。只有一点除外,如果表中的一个旧记录与一个用于PRIMARY KEY或一个UNIQUE索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。请参见13.2.4节,“INSERT语法”。 注意,...

    MySQL的Replace into 与Insert into on duplicate key update真正的不同之处

    今天听同事介绍oracle到mysql的数据migration,他用了Insert into ..... on duplicate key update ...,我当时就想怎么不用Replace呢,于是回来就仔细查了下,它们果然还是有区别的

    MySQL REPLACE死锁问题深入剖析1

    MySQL REPLACE死锁问题深剖析姜承尧IT圈最会讲故事的破产码农上周五发布的MySQL ACE或许都说不清的死锁问题例,很多同学跃跃欲试想要尝试年薪10

    MySQL replace into 语句浅析(二)

    本章内容通过一个例子说明 replace into 带来的潜在的数据质量风险,当涉及replace into操作的表含有自增主键时,主备切换后会造成数据覆盖等不一致的情况发生。 二 案例分析 在主库上操作 代码如下: root@test 12:36...

    MySQL使用Replace操作时造成数据丢失的问题解决

    公司开发人员在更新数据时使用了 replace into 语句,由于使用不当导致了数据的大量丢失,到底是如何导致的数据丢失本文对此进行分析。 一、问题说明 公司开发人员在更新数据时使用了 replace into 语句,由于使用...

    MySQL中REPLACE INTO和INSERT INTO的区别分析

    注意,除非表有一个PRIMARY KEY或UNIQUE索引,否则,使用一个REPLACE语句没有意义。该语句会与INSERT相同,因为没有索引被用于确定是否新行复制了其它的行。[separator] 所有列的值均取自在REPLACE语句中被指定的值...

    MySQL中replace into语句的用法详解

    if not exists (select 1 from table where id = 1) insert into table(id, update_time) values(1, getdate()) else update table set update_time = getdate() where id = 1 在MySQL 中也可以先select,判断是否...

    mysql 中 replace into 与 insert into on duplicate key update 的用法和不同点实例分析

    本文实例讲述了mysql 中 replace into 与 insert into on duplicate key update 的用法和不同点。分享给大家供大家参考,具体如下: replace into和insert into on duplicate key update都是为了解决我们平时的一个...

Global site tag (gtag.js) - Google Analytics