六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網(wǎng)中心:是一個免費提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

案例詳細(xì)說明innodb_autoinc_lock_mode方法

[摘要]下面小編就為大家?guī)硪黄P(guān)于MySQL innodb_autoinc_lock_mode介紹。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧innodb_autoinc_lock_mode這個參數(shù)控制著在向有auto_increment 列的表插入數(shù)據(jù)時,相關(guān)鎖的行為...
下面小編就為大家?guī)硪黄P(guān)于MySQL innodb_autoinc_lock_mode介紹。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

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)推薦】

1. Mysql免費視頻教程

2. 詳解innodb_index_stats導(dǎo)入數(shù)據(jù)時提示表主鍵沖突的錯誤

3. 實例詳解mysql中innodb_autoinc_lock_mode

4. MySQL中添加新用戶權(quán)限的實例詳解

5. 實例詳解mysql中init_connect方法

以上就是實例詳解innodb_autoinc_lock_mode方法的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門到精通的SQL知識。




主站蜘蛛池模板: 亚洲一区2区三区4区5区 | 青草久久精品亚洲综合专区 | 亚洲激情久久 | 午夜精品久久久久久久第一页 | 伊人久久91 | 欧美在线三级 | 三级黄免费 | 日本理论视频 | 日本人的一区二区三区四区 | 亚洲五月综合网色九月色 | 亚洲成色www久久网站 | 四虎影院海外永久 | 亚洲a毛片| 午夜老司机福利 | 特片网在线观看 | 四虎国产一区二区三区 | 午夜国产福利在线观看 | 欧美午夜一区 | 四虎影院在线播放 | 人妖女天堂视频在线96 | 欧美亚洲春色系列 | 全国男人的天堂网站 | 一级毛片一片毛 | 日韩精品小视频 | 最新中文字幕免费视频 | 性生生活三级视频观看 | 天天做夜夜做久久做狠狠 | 欧美系列在线播放 | 日韩激情无码免费毛片 | 日韩精品免费一线在线观看 | 日韩中文字幕免费 | 天天拍拍夜夜出水 | 青春草在线观看播放免费视频 | 四虎影院在线网址 | 亚洲成人自拍 | 天天狠天天透天天伊人 | 天天影视色香欲综合网天天录日日录 | 欧美综合图片区 | 十八毛片 | 亚洲国产成人影院播放 | 日韩成人免费视频 |