mysql⾃增idreplace_MySQL--REPLACEINTO更新⾃增列值
引发的异常
##=====================================================================##
测试环境:
MySQL版本:MySQL 5.7.19
复制模式:ROW
##=====================================================================##
执⾏下⾯操作:
##测试脚本:CREATE TABLET_AUTO_TEST
(
IDINT AUTO_INCREMENT PRIMARY KEY,
C1INT NOT NULL,UNIQUE KEYUNI_C1(C1)
)INSERT INTO T_AUTO_TEST(ID,C1)VALUES(99,99);REPLACE INTO T_AUTO_TEST(ID,C1)VALUES(101,99);
##在主库上和从库上查看该表当前⾃增值:
SELECTTABLE_SCHEMA,TABLE_NAME,AUTO_INCREMENTFROMinformation_schema.tablesWHERE
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'
##=====================================================================##
mysql删除重复的数据保留一条原因分析:
1、在MySQL中,只有INSERT语句才能导致表的⾃增ID发⽣变化,
2、在主库上执⾏REPLACE INTO时,由于唯⼀索引列上存在数据冲突,先删除重复数据再插⼊新数据,插⼊操作导致主库上表的⾃增初始值发⽣变化。
3、步骤2操作在主库上执⾏提交后,按照数据更新情况,BINLOG中会⽣成UPDATE类型的⽇志,UPDATE操作并不触发从库上⾃增初始值发⽣变化。
4、主从发⽣变化后,从库的⾃增值从100开始增加,当增加到102时,当前表中已存在102的记录,因此报主键重复。
##=====================================================================##
总结:
1、REPLACE INTO属于MySQL特有语法,在使⽤过程中,应避免REPLACE时对⾃增列进⾏数据更新。
##=====================================================================##

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。