欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于MySQL innodb_autoinc_lock_mode介紹

 更新時(shí)間:2017年03月18日 11:14:51   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇關(guān)于MySQL innodb_autoinc_lock_mode介紹。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

innodb_autoinc_lock_mode這個(gè)參數(shù)控制著在向有auto_increment 列的表插入數(shù)據(jù)時(shí),相關(guān)鎖的行為;

通過(guò)對(duì)它的設(shè)置可以達(dá)到性能與安全(主從的數(shù)據(jù)一致性)的平衡

【0】我們先對(duì)insert做一下分類(lèi)

首先insert大致上可以分成三類(lèi):

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 的說(shuō)明

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語(yǔ)句("insert like") 都要在語(yǔ)句開(kāi)始的時(shí)候得到一個(gè)表級(jí)的auto_inc鎖,在語(yǔ)句結(jié)束的時(shí)候才釋放這把鎖,注意呀,這里說(shuō)的是語(yǔ)句級(jí)而不是事務(wù)級(jí)的,一個(gè)事務(wù)可能包涵有一個(gè)或多個(gè)語(yǔ)句。

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

4、由于在這種模式下auto_inc鎖一直要保持到語(yǔ)句的結(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語(yǔ)句;總的來(lái)說(shuō)這個(gè)對(duì)復(fù)制也是安全的(它保證了基于語(yǔ)句復(fù)制的安全)

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

【1.3】interleaved(innodb_autoinc_lock_mode=2) 模式

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

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

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

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

例子:不要沒(méi)事去更新一個(gè)auto_increment 列的值

第一步:重現(xiàn)一下場(chǎng)景

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ā)問(wèn)題的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'

第四步:對(duì)問(wèn)題的總結(jié)

執(zhí)行完第一步的時(shí)候mysql知道下一個(gè)auto_increment值是4。

執(zhí)行完第二步的時(shí)候mysql并不知道4已經(jīng)被人為的占用了,所以執(zhí)行第三步的時(shí)候就出錯(cuò)了。

以上這篇關(guān)于MySQL innodb_autoinc_lock_mode介紹就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Windows下MySQL5.7.18安裝教程

    Windows下MySQL5.7.18安裝教程

    這篇文章主要為大家詳細(xì)介紹了Windows下MySQL5.7.18安裝教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • 深入理解MySQL事務(wù)特性與自動(dòng)提交

    深入理解MySQL事務(wù)特性與自動(dòng)提交

    事務(wù)以及事務(wù)隔離機(jī)制,其實(shí)是所有關(guān)系型數(shù)據(jù)庫(kù)都有的問(wèn)題,本文主要介紹了深入理解MySQL事務(wù)特性與自動(dòng)提交,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-07-07
  • MySQL按年/月/周/日/小時(shí)分組查詢(xún)、排序、limit及判空用法實(shí)例

    MySQL按年/月/周/日/小時(shí)分組查詢(xún)、排序、limit及判空用法實(shí)例

    我們?cè)谟肕ysql抽取數(shù)據(jù)時(shí)候,經(jīng)常需要按照天、周、月等不同的粒度對(duì)數(shù)據(jù)進(jìn)行分組統(tǒng)計(jì),下面這篇文章主要給大家介紹了關(guān)于MySQL按年/月/周/日/小時(shí)分組查詢(xún)、排序、limit及判空用法的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • iOS開(kāi)發(fā)runloop運(yùn)行循環(huán)機(jī)制學(xué)習(xí)

    iOS開(kāi)發(fā)runloop運(yùn)行循環(huán)機(jī)制學(xué)習(xí)

    這篇文章主要為大家介紹了iOS開(kāi)發(fā)runloop運(yùn)行循環(huán)的機(jī)制學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • mysql三張表連接建立視圖

    mysql三張表連接建立視圖

    本篇文章給大家分享了mysql三張表連接建立視圖的相關(guān)知識(shí)點(diǎn),有需要的朋友可以參考下。
    2018-06-06
  • ubuntu下在docker中安裝mysql5.6 的方法

    ubuntu下在docker中安裝mysql5.6 的方法

    這篇文章主要介紹了ubuntu下在docker中安裝mysql5.6 的方法,需要的朋友可以參考下
    2017-05-05
  • mysql批量執(zhí)行sql文件的方法

    mysql批量執(zhí)行sql文件的方法

    下面小編就為大家?guī)?lái)一篇mysql批量執(zhí)行sql文件的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編 過(guò)來(lái)看看吧
    2016-10-10
  • mysql安裝忘記初始密碼簡(jiǎn)單有效的解決方法

    mysql安裝忘記初始密碼簡(jiǎn)單有效的解決方法

    在本篇文章里小編給大家整理的是一篇關(guān)于mysql安裝忘記初始密碼簡(jiǎn)單有效的解決方法,有需要的朋友們參考學(xué)習(xí)下。
    2020-01-01
  • Mysql鎖機(jī)制之行鎖、表鎖、死鎖的實(shí)現(xiàn)

    Mysql鎖機(jī)制之行鎖、表鎖、死鎖的實(shí)現(xiàn)

    本文主要介紹了Mysql鎖機(jī)制之行鎖、表鎖、死鎖的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • MySQL gtid的具體使用

    MySQL gtid的具體使用

    本文詳細(xì)介紹了MySQL的GTID的概念、格式、相關(guān)參數(shù)以及生命周期,同時(shí)還講解了GTID的自動(dòng)定位、復(fù)制監(jiān)控與管理等功能,GTID是MySQL復(fù)制環(huán)境中的一種唯一標(biāo)識(shí),可以有效避免重復(fù)復(fù)制的現(xiàn)象,保持?jǐn)?shù)據(jù)一致,文章中還列舉了多個(gè)示例,感興趣的可以了解一下
    2024-10-10

最新評(píng)論