国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

關(guān)于MySQL innodb_autoinc_lock_mode介紹

2024-07-24 12:52:16
字體:
供稿:網(wǎng)友

innodb_autoinc_lock_mode這個(gè)參數(shù)控制著在向有auto_increment 列的表插入數(shù)據(jù)時(shí),相關(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有三個(gè)取值:

1、0 這個(gè)表示tradition 傳統(tǒng)

2、1 這個(gè)表示consecutive 連續(xù)

3、2 這個(gè)表示interleaved 交錯(cuò)

【1.1】tradition(innodb_autoinc_lock_mode=0) 模式:

1、它提供了一個(gè)向后兼容的能力

2、在這一模式下,所有的insert語句("insert like") 都要在語句開始的時(shí)候得到一個(gè)表級的auto_inc鎖,在語句結(jié)束的時(shí)候才釋放這把鎖,注意呀,這里說的是語句級而不是事務(wù)級的,一個(gè)事務(wù)可能包涵有一個(gè)或多個(gè)語句。

3、它能保證值分配的可預(yù)見性,與連續(xù)性,可重復(fù)性,這個(gè)也就保證了insert語句在復(fù)制到slave的時(shí)候還能生成和master那邊一樣的值(它保證了基于語句復(fù)制的安全)。

4、由于在這種模式下auto_inc鎖一直要保持到語句的結(jié)束,所以這個(gè)就影響到了并發(fā)的插入。

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

1、這一模式下去simple insert 做了優(yōu)化,由于simple insert一次性插入值的個(gè)數(shù)可以立馬得到 確定,所以mysql可以一次生成幾個(gè)連續(xù)的值,用于這個(gè)insert語句;總的來說這個(gè)對復(fù)制也是安全的(它保證了基于語句復(fù)制的安全)

2、這一模式也是mysql的默認(rèn)模式,這個(gè)模式的好處是auto_inc鎖不要一直保持到語句的結(jié)束,只要語句得到了相應(yīng)的值后就可以提前釋放鎖

【1.3】interleaved(innodb_autoinc_lock_mode=2) 模式

1、由于這個(gè)模式下已經(jīng)沒有了auto_inc鎖,所以這個(gè)模式下的性能是最好的;但是它也有一個(gè)問題,就是對于同一個(gè)語句來說它所得到的auto_incremant值可能不是連續(xù)的。

【2】如果你的二進(jìn)制文件格式是mixed | row 那么這三個(gè)值中的任何一個(gè)對于你來說都是復(fù)制安全的。

由于現(xiàn)在mysql已經(jīng)推薦把二進(jìn)制的格式設(shè)置成row,所以在binlog_format不是statement的情況下最好是innodb_autoinc_lock_mode=2 這樣可能知道更好的性能。

最后以一個(gè)關(guān)于auto_increment 的例子來結(jié)束

例子:不要沒事去更新一個(gè)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 |+---+
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 通道| 五峰| 钦州市| 乌兰浩特市| 锦屏县| 土默特左旗| 阳信县| 油尖旺区| 乌兰察布市| 西吉县| 新巴尔虎右旗| 茶陵县| 昆明市| 兴仁县| 三原县| 沙田区| 渭南市| 额济纳旗| 嘉义市| 宝山区| 浪卡子县| 玉门市| 南阳市| 洛浦县| 洛宁县| 上思县| 深州市| 星子县| 龙川县| 余庆县| 梁山县| 扶风县| 吴堡县| 保山市| 固安县| 峨眉山市| 侯马市| 大方县| 白玉县| 通辽市| 康平县|