婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 關于MySQL innodb_autoinc_lock_mode介紹

關于MySQL innodb_autoinc_lock_mode介紹

熱門標簽:哈爾濱云外呼系統運營商 邯鄲400電話注冊辦理 地圖標注直通車 永州智能外呼系統 趙縣地圖標注 南寧智能電銷機器人價格 遂寧400電話申請 電銷機器人市場價 dq8 全地圖標注

innodb_autoinc_lock_mode這個參數控制著在向有auto_increment 列的表插入數據時,相關鎖的行為;

通過對它的設置可以達到性能與安全(主從的數據一致性)的平衡

【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 傳統

2、1 這個表示consecutive 連續

3、2 這個表示interleaved 交錯

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

1、它提供了一個向后兼容的能力

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

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

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

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

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

2、這一模式也是mysql的默認模式,這個模式的好處是auto_inc鎖不要一直保持到語句的結束,只要語句得到了相應的值后就可以提前釋放鎖

【1.3】interleaved(innodb_autoinc_lock_mode=2) 模式

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

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

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

最后以一個關于auto_increment 的例子來結束

例子:不要沒事去更新一個auto_increment 列的值

第一步:重現一下場景

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 |
+---+

第二步:重現一下引發問題的SQL

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

第三步:重現一下總是的表現形式

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

第四步:對問題的總結

執行完第一步的時候mysql知道下一個auto_increment值是4。

執行完第二步的時候mysql并不知道4已經被人為的占用了,所以執行第三步的時候就出錯了。

以上這篇關于MySQL innodb_autoinc_lock_mode介紹就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • InnoDB 類型MySql恢復表結構與數據
  • MySQL啟動時InnoDB引擎被禁用了的解決方法
  • mysql執行sql文件報錯Error: Unknown storage engine‘InnoDB’的解決方法
  • mysql innodb 異常修復經驗分享
  • mysql innodb的監控(系統層,數據庫層)
  • Mysql更換MyISAM存儲引擎為Innodb的操作記錄總結
  • MySQL優化之InnoDB優化
  • MySQL存儲引擎中MyISAM和InnoDB區別詳解
  • MySQL提示The InnoDB feature is disabled需要開啟InnoDB的解決方法
  • MySQL中Innodb的事務隔離級別和鎖的關系的講解教程
  • 詳解MySQL中InnoDB的存儲文件

標簽:張家界 浙江 阿里 南寧 中衛 上海 定西 鄂州

巨人網絡通訊聲明:本文標題《關于MySQL innodb_autoinc_lock_mode介紹》,本文關鍵詞  關于,MySQL,innodb,autoinc,lock,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《關于MySQL innodb_autoinc_lock_mode介紹》相關的同類信息!
  • 本頁收集關于關于MySQL innodb_autoinc_lock_mode介紹的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 沾化县| 和顺县| 永新县| 肇州县| 和林格尔县| 尼玛县| 宜兴市| 栾城县| 商城县| 资溪县| 闻喜县| 丰县| 宜春市| 阿克苏市| 榆社县| 鄂托克旗| 闵行区| 京山县| 克什克腾旗| 菏泽市| 冕宁县| 中山市| 台中县| 南漳县| 亳州市| 锦州市| 裕民县| 阳江市| 舟曲县| 开阳县| 石狮市| 新泰市| 武山县| 普格县| 灵山县| 阳西县| 滁州市| 彰化市| 冀州市| 秦皇岛市| 九寨沟县|