慎重使用MySQL auto_increment

时间:2023-02-08 05:00:01
在使用MySQL中,常常会在表中建立一个自增的ID字段,利用自增ID可以高速建立索引,也是MySQL官方比較推荐的一种方式,可是,这样的方式在大量数据且配置主从时,可能会出现因为自增ID导致同步失败的情况
首先须要了解一点
Mysql主从同步主要通过bin log来同步,而MySQl中bin log最大值为1G,

慎重使用MySQL auto_increment

这样的情况触发条件例如以下:
1、数据库配置主从同步
2、表存在自增ID
3、表数据量大,

假设在主上运行insert into…select…类SQL,该SQL事物超过1G时,MySQL会将该SQL以row模式同步从上,即同步为insert into values(.......),而此时数据量超过1G,即超过了MySQL bin log同意的最大值,所以主从同步失败,仅仅能删除该自增字段才干恢复主从
因此在数据量非常大且存在上述计算SQL的表上,慎重使用自增字段