MySQL--REPLACE INTO与自增

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

执行下面操做:spa

##测试脚本:
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'code

##=====================================================================##
缘由分析:
一、在MySQL中,只有INSERT语句才能致使表的自增ID发生变化,
二、在主库上执行REPLACE INTO时,因为惟一索引列上存在数据冲突,先删除重复数据再插入新数据,插入操做致使主库上表的自增初始值发生变化。
三、步骤2操做在主库上执行提交后,按照数据更新状况,BINLOG中会生成UPDATE类型的日志,UPDATE操做并不触发从库上自增初始值发生变化。
四、主从发生变化后,从库的自增值从100开始增长,当增长到102时,当前表中已存在102的记录,所以报主键重复。orm

##=====================================================================##blog

总结:索引

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

##=====================================================================##table

相关文章
相关标签/搜索