Mysql之浅析AUTO_INCREMENT

2022-02-09  本文已影响0人  穹柏

AUTO_INCREMENT用于为表中的列设置一个自增序列,在非集群模式下,用它来为主键列自动生成值是一件很方便的事。并且,Mysql提供了一系列的锁机制来保证它的性能跟可靠性,通过这些锁机制,我们可以让它变得很高效。

术语

先来了解后面将要用到的术语。

锁模式

锁模式在启动时通过innodb_autoinc_lock_mode这个变量来配置,它有3个值:0, 1, 2。分别对应traditional(传统)、consecutive(连续)、interleaved(交错)3种模式。

Mysql5.6~5.7里,这个配置项的默认值是1,从Mysql8开始,它的默认值2。这个一方面是因为模式2的性能更好,另一方面是因为从Mysql8开始,默认的主从复制的方式由statement-based 改为了row basedrow based 能保证innodb_autoinc_lock_mode=2时主从复制时的数据不会出现不一致的问题。好了,下面开始详细了解这三种锁模式吧!

注意点

总结

  1. 单实例下,可以设置innodb_autoinc_lock_mode=2
  2. 主从
    1. 复制模式为statement-based,设置innodb_autoinc_lock_mode=1
    2. 复制模式为row based或者mixed-format,设置innodb_autoinc_lock_mode=2

参考链接

上一篇下一篇

猜你喜欢

热点阅读