日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

【转】MySQL innodb_autoinc_lock_mode 详解 ,并发插入时主键冲突的解决方案

發(fā)布時間:2024/9/5 数据库 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【转】MySQL innodb_autoinc_lock_mode 详解 ,并发插入时主键冲突的解决方案 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

本文轉(zhuǎn)載于 http://www.cnblogs.com/JiangLe/p/6362770.html

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

通過對它的設(shè)置可以達到性能與安全(主從的數(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、它能保證值分配的可預見性,與連續(xù)性,可重復性,這個也就保證了insert語句在復制到slave
? ? ? ? ? 的時候還能生成和master那邊一樣的值(它保證了基于語句復制的安全)。
? ? ?4、由于在這種模式下auto_inc鎖一直要保持到語句的結(jié)束,所以這個就影響到了并發(fā)的插入。

?

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

  1、這一模式下去simple insert 做了優(yōu)化,由于simple insert一次性插入值的個數(shù)可以立馬得到
? ? ? ? ? 確定,所以mysql可以一次生成幾個連續(xù)的值,用于這個insert語句;總的來說這個對復制也是安全的
? ? ? ? ? (它保證了基于語句復制的安全)
  2、這一模式也是mysql的默認模式,這個模式的好處是auto_inc鎖不要一直保持到語句的結(jié)束,只要
? ? ? ? ? 語句得到了相應(yīng)的值后就可以提前釋放鎖

?

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

?

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

  由于現(xiàn)在mysql已經(jīng)推薦把二進制的格式設(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í)行第三步的時候就出錯了。

?

轉(zhuǎn)載于:https://www.cnblogs.com/Yiran583/p/6694075.html

總結(jié)

以上是生活随笔為你收集整理的【转】MySQL innodb_autoinc_lock_mode 详解 ,并发插入时主键冲突的解决方案的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。