当前位置:首页 >综合 >故障案例:MySQL唯一索引有重复值,官方却说This is not a bug 有重不会进行物理读

故障案例:MySQL唯一索引有重复值,官方却说This is not a bug 有重不会进行物理读

2024-05-16 15:31:02 [百科] 来源:避面尹邢网

故障案例:MySQL唯一索引有重复值,故障官方官方却说This 案例is not a bug

作者:飞鱼过天 数据库 MySQL unique_checks=0时导致,在bug(106121)列表中官方解释的索引原因:该参数关闭,维护唯一索引时,有重不会进行物理读,复值只会进行内存读,却说来确保唯一索引的故障官方唯一性,即如果内存中有冲突数据就报1062,案例如果内存中没有冲突数据插入成功,索引不会进行io来将唯一索引相关的有重数据页拉取到内存。

一、复值问题:

MySQL5.7.38主从架构,却说主节点唯一索引上(唯一索引不是故障官方主键)有重复值,全部从节点报1062,案例SQL线程状态异常,索引根据SQL线程报的binlog位置点,insert 数据时有重复值,插入失败

二、原因:

unique_checks=0时导致,在bug(106121)列表中官方解释的原因:该参数关闭,维护唯一索引时,不会进行物理读,只会进行内存读,来确保唯一索引的唯一性,即如果内存中有冲突数据就报1062,如果内存中没有冲突数据插入成功,不会进行io来将唯一索引相关的数据页拉取到内存。

故障案例:MySQL唯一索引有重复值,官方却说This is not a bug 有重不会进行物理读

官方的回复“IMHO this is not a bug”,我理解的意思“不要你觉得,我要我觉得,我就是这么玩的”。

故障案例:MySQL唯一索引有重复值,官方却说This is not a bug 有重不会进行物理读

三、故障解决方案:

1.临时解决方案

故障案例:MySQL唯一索引有重复值,官方却说This is not a bug 有重不会进行物理读

  • 恢复主从:

在从节点开启会话

set sql_log_bin=0

删除表的唯一索引

重新启动复制线程

缺点是:不能够解决数据重复的问题,切换主从后会面临更多重复数据的问题,如果从节点接收查请求且使用到了原唯一索引的字段,那sql效率会严重下降,但是可以解决主从复制停止的问题

2.永久解决方案

  1. 业务自己去重,不要插入重复数据
  2. 参数unique_checks保持为1
  3. 关于重复的业务数据:与业务交流,确定重复数据的处理方式

四、复现步骤:

1. 表结构:

mysql> create database wl;
mysql> show create table wl.lgf\G

(责任编辑:休闲)

    推荐文章
    热点阅读