innodb_autoinc_lock_mode這個參數(shù)控制著在向有auto_increment 列的表插入數(shù)據(jù)時,相關(guān)鎖的行為;
通過對它的設(shè)置可以達(dá)到性能與安全(主從的數(shù)據(jù)一致性)的平衡
【0】我們先對insert做一下分類
首先insert大致上可以分成三類:
1、simple insert 如insert into t(name) values('test')
2、bulk insert 如load data | insert into ... select .... from ....
3、mixed insert 如insert into t(id,name) values(1,'a'),(null,'b'),(5,'c');
【1】innodb_autoinc_lock_mode 的說明
innodb_auto_lockmode有三個取值:
1、0 這個表示tradition 傳統(tǒng)
2、1 這個表示consecutive 連續(xù)
3、2 這個表示interleaved 交錯
【1.1】tradition(innodb_autoinc_lock_mode=0) 模式:
1、它提供了一個向后兼容的能力
2、在這一模式下,所有的insert語句("insert like") 都要在語句開始的時候得到一個表級的auto_inc鎖,在語句結(jié)束的時候才釋放這把鎖,注意呀,這里說的是語句級而不是事務(wù)級的,一個事務(wù)可能包涵有一個或多個語句。
3、它能保證值分配的可預(yù)見性,與連續(xù)性,可重復(fù)性,這個也就保證了insert語句在復(fù)制到slave的時候還能生成和master那邊一樣的值(它保證了基于語句復(fù)制的安全)。
4、由于在這種模式下auto_inc鎖一直要保持到語句的結(jié)束,所以這個就影響到了并發(fā)的插入。
【1.2】consecutive(innodb_autoinc_lock_mode=1) 模式:
1、這一模式下去simple insert 做了優(yōu)化,由于simple insert一次性插入值的個數(shù)可以立馬得到 確定,所以mysql可以一次生成幾個連續(xù)的值,用于這個insert語句;總的來說這個對復(fù)制也是安全的(它保證了基于語句復(fù)制的安全)
2、這一模式也是mysql的默認(rèn)模式,這個模式的好處是auto_inc鎖不要一直保持到語句的結(jié)束,只要語句得到了相應(yīng)的值后就可以提前釋放鎖
【1.3】interleaved(innodb_autoinc_lock_mode=2) 模式
1、由于這個模式下已經(jīng)沒有了auto_inc鎖,所以這個模式下的性能是最好的;但是它也有一個問題,就是對于同一個語句來說它所得到的auto_incremant值可能不是連續(xù)的。
【2】如果你的二進(jìn)制文件格式是mixed | row 那么這三個值中的任何一個對于你來說都是復(fù)制安全的。
由于現(xiàn)在mysql已經(jīng)推薦把二進(jìn)制的格式設(shè)置成row,所以在binlog_format不是statement的情況下最好是innodb_autoinc_lock_mode=2 這樣可能知道更好的性能。
最后以一個關(guān)于auto_increment 的例子來結(jié)束
例子:不要沒事去更新一個auto_increment 列的值
第一步:重現(xiàn)一下場景
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 |
+---+
第二步:重現(xiàn)一下引發(fā)問題的SQL
update t set x=4 where x=1;
select * from t;
+---+
| x |
+---+
| 2 |
| 3 |
| 4 |
+---+
第三步:重現(xiàn)一下總是的表現(xiàn)形式
insert into t(x) values(0);
ERROR 1062 (23000): Duplicate entry '4' for key 'PRIMARY'
第四步:對問題的總結(jié)
執(zhí)行完第一步的時候mysql知道下一個auto_increment值是4。
執(zhí)行完第二步的時候mysql并不知道4已經(jīng)被人為的占用了,所以執(zhí)行第三步的時候就出錯了。
以上這篇關(guān)于MySQL innodb_autoinc_lock_mode介紹就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:- InnoDB 類型MySql恢復(fù)表結(jié)構(gòu)與數(shù)據(jù)
- MySQL啟動時InnoDB引擎被禁用了的解決方法
- mysql執(zhí)行sql文件報錯Error: Unknown storage engine‘InnoDB’的解決方法
- mysql innodb 異常修復(fù)經(jīng)驗分享
- mysql innodb的監(jiān)控(系統(tǒng)層,數(shù)據(jù)庫層)
- Mysql更換MyISAM存儲引擎為Innodb的操作記錄總結(jié)
- MySQL優(yōu)化之InnoDB優(yōu)化
- MySQL存儲引擎中MyISAM和InnoDB區(qū)別詳解
- MySQL提示The InnoDB feature is disabled需要開啟InnoDB的解決方法
- MySQL中Innodb的事務(wù)隔離級別和鎖的關(guān)系的講解教程
- 詳解MySQL中InnoDB的存儲文件