MYSQL教程关于MySQL innodb_autoinc_lock_mode介绍

MYSQL教程关于MySQL innodb_autoinc_lock_mode介绍,第1张

概述介绍《MYSQL教程关于MySQL innodb_autoinc_lock_mode介绍》开发教程,希望对您有用。

《MysqL教程关于MysqL innodb_autoinc_lock_mode介绍》要点:
本文介绍了MysqL教程关于MysqL innodb_autoinc_lock_mode介绍,希望对您有用。如果有疑问,可以联系我们。

innodb_autoinc_lock_mode这个参数控制着在向有auto_increment 列的表插入数据时,相关锁的行为;MysqL入门

通过对它的设置可以达到性能与安全(主从的数据一致性)的平衡MysqL入门

【0】我们先对insert做一下分类MysqL入门

首先insert大致上可以分成三类:
MysqL入门

1、simple insert 如insert into t(name) values('test')
MysqL入门

2、bulk insert 如load data | insert into ... select .... from ....
MysqL入门

3、mixed insert 如insert into t(ID,name) values(1,'a'),(null,'b'),(5,'c');MysqL入门

【1】innodb_autoinc_lock_mode 的说明MysqL入门

innodb_auto_lockmode有三个取值:
MysqL入门

1、0 这个表示Tradition 传统
MysqL入门

2、1 这个表示consecutive 连续
MysqL入门

3、2 这个表示interleaved 交错MysqL入门

【1.1】Tradition(innodb_autoinc_lock_mode=0) 模式:MysqL入门

1、它提供了一个向后兼容的能力
MysqL入门

2、在这一模式下,所有的insert语句("insert like") 都要在语句开始的时候得到一个表级的auto_inc锁,在语句结束的时候才释放这把锁,注意呀,这里说的是语句级而不是事务级的,一个事务可能包涵有一个或多个语句.
MysqL入门

3、它能保证值分配的可预见性,与连续性,可重复性,这个也就保证了insert语句在复制到slave的时候还能生成和master那边一样的值(它保证了基于语句复制的安全).
MysqL入门

4、由于在这种模式下auto_inc锁一直要保持到语句的结束,所以这个就影响到了并发的插入.MysqL入门

 【1.2】consecutive(innodb_autoinc_lock_mode=1) 模式:MysqL入门

1、这一模式下去simple insert 做了优化,由于simple insert一次性插入值的个数可以立马得到 确定,所以MysqL可以一次生成几个连续的值,用于这个insert语句;总的来说这个对复制也是安全的(它保证了基于语句复制的安全)
MysqL入门

2、这一模式也是MysqL的默认模式,这个模式的好处是auto_inc锁不要一直保持到语句的结束,只要语句得到了相应的值后就可以提前释放锁MysqL入门

【1.3】interleaved(innodb_autoinc_lock_mode=2) 模式
MysqL入门

1、由于这个模式下已经没有了auto_inc锁,所以这个模式下的性能是最好的;但是它也有一个问题,就是对于同一个语句来说它所得到的auto_incremant值可能不是连续的.MysqL入门

【2】如果你的二进制文件格式是mixed | row 那么这三个值中的任何一个对于你来说都是复制安全的.MysqL入门

由于现在MysqL已经推荐把二进制的格式设置成row,所以在binlog_format不是statement的情况下最好是innodb_autoinc_lock_mode=2 这样可能知道更好的性能.MysqL入门

最后以一个关于auto_increment 的例子来结束MysqL入门

例子:不要没事去更新一个auto_increment 列的值MysqL入门

第一步:重现一下场景MysqL入门

create table t(x int auto_increment not null primary key);insert into t(x) values(0),(null),(3);select * from t;+---+| x |+---+| 1 || 2 || 3 |+---+

第二步:重现一下引发问题的sqlMysqL入门

update t set x=4 where x=1;select * from t;+---+| x |+---+| 2 || 3 || 4 |+---+

第三步:重现一下总是的表现形式MysqL入门

insert into t(x) values(0);ERROR 1062 (23000): Duplicate entry '4' for key 'PRIMARY'

第四步:对问题的总结MysqL入门

执行完第一步的时候MysqL知道下一个auto_increment值是4.MysqL入门

执行完第二步的时候MysqL并不知道4已经被人为的占用了,所以执行第三步的时候就出错了.MysqL入门

以上这篇关于MysqL innodb_autoinc_lock_mode介绍就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持内存溢出PHP.MysqL入门

总结

以上是内存溢出为你收集整理的MYSQL教程关于MySQL innodb_autoinc_lock_mode介绍全部内容,希望文章能够帮你解决MYSQL教程关于MySQL innodb_autoinc_lock_mode介绍所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://www.outofmemory.cn/sjk/1163036.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存