zoukankan      html  css  js  c++  java
  • MySQL--REPLACE INTO更新自增列值引发的异常

    ##=====================================================================##
    测试环境:
    MySQL版本:MySQL 5.7.19
    复制模式:ROW
    ##=====================================================================##

    执行下面操作:

    ##测试脚本:
    CREATE TABLE T_AUTO_TEST
    (
        ID INT AUTO_INCREMENT PRIMARY KEY,
        C1 INT NOT NULL,
        UNIQUE KEY UNI_C1(C1)
    )
    
    INSERT INTO T_AUTO_TEST(ID,C1)VALUES(99,99);
    REPLACE INTO T_AUTO_TEST(ID,C1)VALUES(101,99);
    
    ##在主库上和从库上查看该表当前自增值:
    SELECT TABLE_SCHEMA,TABLE_NAME,AUTO_INCREMENT 
    FROM information_schema.tables 
    WHERE table_name='T_AUTO_TEST';
    
    ##发现主库上自增值为102,而从库上为100,当主从发生切换后,正常插入数据:
    INSERT INTO T_AUTO_TEST(C1)VALUES(103);
    INSERT INTO T_AUTO_TEST(C1)VALUES(104);

    发生报错:

    ERROR 1062 (23000): Duplicate entry '101' for key 'PRIMARY'

    ##=====================================================================##
    原因分析:
    1、在MySQL中,只有INSERT语句才能导致表的自增ID发生变化,
    2、在主库上执行REPLACE INTO时,由于唯一索引列上存在数据冲突,先删除重复数据再插入新数据,插入操作导致主库上表的自增初始值发生变化。
    3、步骤2操作在主库上执行提交后,按照数据更新情况,BINLOG中会生成UPDATE类型的日志,UPDATE操作并不触发从库上自增初始值发生变化。
    4、主从发生变化后,从库的自增值从100开始增加,当增加到102时,当前表中已存在102的记录,因此报主键重复。

    ##=====================================================================##

    总结:

    1、REPLACE INTO属于MySQL特有语法,在使用过程中,应避免REPLACE时对自增列进行数据更新。

    ##=====================================================================##

  • 相关阅读:
    62. 不同路径-dp-中等
    49. 字母异位词分组-字符串-中等
    34. 在排序数组中查找元素的第一个和最后一个位置-二分查找-中等
    33. 搜索旋转排序数组-二分查找-中等
    221. 最大正方形-dp-中等难度
    38. 外观数列-字符串-中等难度
    mysql-索引/视图/存储过程/函数/触发器
    mysql-常用命令
    MDK5.34发布,AC6升级至V6.16(2021-03-19)
    STM32H7的CAN FD教程笔记
  • 原文地址:https://www.cnblogs.com/gaogao67/p/10392680.html
Copyright © 2011-2022 走看看