使用on duplicate key update语法有时是很方便,可是会有一个影响:默认状况下,每次更新都会更新该表的自增主键ID,若是更新频率很快,会致使主键ID自增的很快,过段时间就超过数字类型的的范围了
解决这个问题,有两种方式:(实际我目前使用的方式是把自增主键ID设置为bigint,也有一部分操做先查询再选择插入OR更新)方法一:拆分红两个动做,先查询,再更新方法二:修改innodb_autoinc_lock_mode参数(不推荐) innodb_autoinc_lock_mode中有3种模式,0,1,2,数据库默认是1的状况下,就会发生上面的那种现象,每次使用insert into .. on duplicate key update 的时候都会把简单自增id增长,无论是发生了insert仍是updateinnodb_autoinc_lock_mode参数详解tradition(innodb_autoinc_lock_mode=0) 模式:一、它提供了一个向后兼容的能力二、在这一模式下,全部的insert语句("insert like") 都要在语句开始的时候获得一个表级的auto_inc锁,在语句结束的时候才释放这把锁,注意呀,这里说的是语句级而不是事务级的,一个事务可能包涵有一个或多个语句。三、它能保证值分配的可预见性,与连续性,可重复性,这个也就保证了insert语句在复制到slave的时候还能生成和master那边同样的值(它保证了基于语句复制的安全)。四、因为在这种模式下auto_inc锁一直要保持到语句的结束,因此这个就影响到了并发的插入。consecutive(innodb_autoinc_lock_mode=1) 模式:一、这一模式下去simple insert 作了优化,因为simple insert一次性插入值的个数能够立马获得肯定,因此mysql能够一次生成几个连续的值,用于这个insert语句;总的来讲这个对复制也是安全的(它保证了基于语句复制的安全)二、这一模式也是mysql的默认模式,这个模式的好处是auto_inc锁不要一直保持到语句的结束,只要语句获得了相应的值后就能够提早释放锁interleaved(innodb_autoinc_lock_mode=2) 模式一、因为这个模式下已经没有了auto_inc锁,因此这个模式下的性能是最好的;可是它也有一个问题,就是对于同一个语句来讲它所获得的auto_incremant值可能不是连续的。