MySQL运用Replace操作时造成数据丢失的问题处理
发布时间:2022-03-15 12:17:54 所属栏目:MySql教程 来源:互联网
导读:公司开发人员在更新数据时使用了 replace into 语句,由于使用不当导致了数据的大量丢失,到底是如何导致的数据丢失本文对此进行分析。 一、问题说明 公司开发人员在更新数据时使用了 replace into 语句,由于使用不当导致了数据的大量丢失,到底是如何导致
公司开发人员在更新数据时使用了 replace into 语句,由于使用不当导致了数据的大量丢失,到底是如何导致的数据丢失本文对此进行分析。 一、问题说明 公司开发人员在更新数据时使用了 replace into 语句,由于使用不当导致了数据的大量丢失,到底是如何导致的数据丢失现分析如下。 二、问题分析 a. REPLACE 原理 REPLACE INTO 原理的官方解释为: REPLACE works exactly like INSERT, except that if an old row in the table has the same value as a new row for a PRIMARY KEY or a UNIQUE index, the old row is deleted before the new row is inserted. b. 问题现象 丢失数据的表结构如下: CREATE TABLE `active_items` ( 执行的replace语句如下(多条): REPLACE INTO active_items(ad_id,score) VALUES('XXXXXXX', 1800); 通过查询binlog找到执行记录,部分如下: ### UPDATE `items`.`active_items` ### @21=0 /* TINYINT meta=0 nullable=0 is_null=0 */ 操作的ad_id已经存在,因此先删除后插入,可以看到除了指定的 ad_id,score,其他字段都变为默认值,导致原有数据丢失(虽然在日志中转为了update) c. 对比测试 接下来我进行了如下测试: MySQL使用Replace操作时造成数据丢失的问题解决 MySQL进行Replace操作时造成数据丢失 左侧使用 REPLACE 语句,右侧使用 DELETE + INSERT 语句,最后结果完全相同 原主键id为1的行被删除,新插入行主键id更新为4,没有指定内容的字段c则插入了默认值 使用 REPLACE 更新了一行数据,MySQL提示受影响行数为2行 综上所述,说明确实是删除一行,插入一行 三、数据恢复 数据丢失或数据错误后,可以有如下几种方式恢复: 业务方自己写脚本恢复 通过MySQL的binlog查出误操作sql,生成反向sql进行数据恢复(适合sql数据量较小的情况) 通过历史备份文件+增量binlog将数据状态恢复到误操作的前一刻。 (编辑:好传媒网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |