佳木斯湛栽影视文化发展公司

主頁(yè) > 知識(shí)庫(kù) > MySQL數(shù)據(jù)庫(kù)鎖機(jī)制原理解析

MySQL數(shù)據(jù)庫(kù)鎖機(jī)制原理解析

熱門標(biāo)簽:百度競(jìng)價(jià)排名 服務(wù)外包 呼叫中心市場(chǎng)需求 Linux服務(wù)器 鐵路電話系統(tǒng) 地方門戶網(wǎng)站 AI電銷 網(wǎng)站排名優(yōu)化

在并發(fā)訪問情況下,很有可能出現(xiàn)不可重復(fù)讀等等讀現(xiàn)象。為了更好的應(yīng)對(duì)高并發(fā),封鎖、時(shí)間戳、樂觀并發(fā)控制(樂觀鎖)、悲觀并發(fā)控制(悲觀鎖)都是并發(fā)控制采用的主要技術(shù)方式。

鎖分類

①、按操作劃分:DML鎖,DDL鎖

②、按鎖的粒度劃分:表級(jí)鎖、行級(jí)鎖、頁(yè)級(jí)鎖

③、按鎖級(jí)別劃分:共享鎖、排他鎖

④、按加鎖方式劃分:自動(dòng)鎖、顯示鎖

⑤、按使用方式劃分:樂觀鎖、悲觀鎖

樂觀鎖和悲觀鎖

樂觀并發(fā)控制和悲觀并發(fā)控制是并發(fā)控制采用的主要方法。樂觀鎖和悲觀鎖不僅在關(guān)系數(shù)據(jù)庫(kù)里應(yīng)用,在Hibernate、Memcache等等也有相關(guān)概念。

悲觀鎖:也即悲觀并發(fā)控制,Pessimistic Concurrency Controller,縮寫PCC。悲觀鎖是指在數(shù)據(jù)處理過程,使數(shù)據(jù)處于鎖定狀態(tài),一般使用數(shù)據(jù)庫(kù)的鎖機(jī)制實(shí)現(xiàn)。

備注,在MySQL中使用悲觀鎖,必須關(guān)閉MySQL的自動(dòng)提交,set autocommit=0。MySQL默認(rèn)使用自動(dòng)提交autocommit模式,也即你執(zhí)行一個(gè)更新操作,MySQL會(huì)自動(dòng)將結(jié)果提交。

例如:使用select...for update方式將數(shù)據(jù)鎖住,也就是開啟了排他鎖

//0.開始事務(wù)
begin;/begin work;/start transaction; (三者選一就可
//1.查詢出商品信息
select status from t_goods where id=1 for update;
//2.根據(jù)商品信息生成訂單
insert into t_orders (id,goods_id) values (null,1);
//3.修改商品status為2
update t_goods set status=2;
//4.提交事務(wù)
commit;/commit work;

悲觀鎖

優(yōu)點(diǎn):悲觀鎖利用數(shù)據(jù)庫(kù)中的鎖機(jī)制來實(shí)現(xiàn)數(shù)據(jù)變化的順序執(zhí)行,這是最有效的辦法

缺點(diǎn):加鎖機(jī)制會(huì)產(chǎn)生額外的開銷,增加產(chǎn)生死鎖的機(jī)會(huì)。一個(gè)事務(wù)用悲觀鎖對(duì)數(shù)據(jù)加鎖之后,其他事務(wù)將不能對(duì)加鎖的數(shù)據(jù)進(jìn)行除了查詢以外的所有操作,如果該事務(wù)執(zhí)行時(shí)間很長(zhǎng),那么其他事務(wù)將一直等待,那勢(shì)必影響我們系統(tǒng)的吞吐量。

樂觀鎖

優(yōu)點(diǎn):樂觀鎖不在數(shù)據(jù)庫(kù)上加鎖,任何事務(wù)都可以對(duì)數(shù)據(jù)進(jìn)行操作,在更新時(shí)才進(jìn)行校驗(yàn),這樣就避免了悲觀鎖造成的吞吐量下降的劣勢(shì)。

缺點(diǎn):樂觀鎖因?yàn)槭峭ㄟ^我們?nèi)藶閷?shí)現(xiàn)的,它僅僅適用于我們自己業(yè)務(wù)中,如果有外來事務(wù)插入,那么就可能發(fā)生錯(cuò)誤。

  • MySQL常用存儲(chǔ)引擎的鎖機(jī)制
  • BDB:支持頁(yè)級(jí)鎖和表級(jí)鎖,默認(rèn)是頁(yè)級(jí)鎖
  • InnoDB:支持行級(jí)鎖和表級(jí)鎖,默認(rèn)是行級(jí)鎖
  • MyISAM Memory:這兩個(gè)存儲(chǔ)引擎都是采用表級(jí)鎖

MySQL中排它鎖和共享鎖

排它鎖(exclusive locck)

排它鎖又叫寫鎖,如果事務(wù)T對(duì)A加上排它鎖,則其它事務(wù)都不能對(duì)A加任何類型的鎖。獲準(zhǔn)排它鎖的事務(wù)既能讀數(shù)據(jù),又能寫數(shù)據(jù)。

用法:SELECT ... FOR UPDATE

共享鎖(share lock)

共享鎖又叫讀鎖,如果事務(wù)T對(duì)A加上共享鎖,則其它事務(wù)只能對(duì)A再加共享鎖,不能加其它鎖。獲準(zhǔn)共享鎖的事務(wù)只能讀數(shù)據(jù),不能寫數(shù)據(jù)。

用法:SELECT ... LOCK IN SHARE MODE;

MySQL中的行級(jí)鎖、表級(jí)鎖和頁(yè)級(jí)鎖

行級(jí)鎖:行級(jí)鎖分為共享鎖和排它鎖。行級(jí)鎖是Mysql中鎖定粒度最細(xì)的鎖。InnoDB引擎支持行級(jí)鎖和表級(jí)鎖,只有在通過索引條件檢索數(shù)據(jù)的時(shí)候,才使用行級(jí)鎖,否就使用表級(jí)鎖。行級(jí)鎖開銷大,加鎖慢,鎖定粒度最小,發(fā)生鎖沖突概率最低,并發(fā)度最高

表級(jí)鎖:表級(jí)鎖分為表共享鎖和表獨(dú)占鎖。表級(jí)鎖開銷小,加鎖快,鎖定粒度大、發(fā)生鎖沖突最高,并發(fā)度最低

頁(yè)級(jí)鎖:頁(yè)級(jí)鎖是MySQL中鎖定粒度介于行級(jí)鎖和表級(jí)鎖中間的一種鎖。表級(jí)鎖速度快,但沖突多,行級(jí)沖突少,但速度慢。所以取了折衷的頁(yè)級(jí),一次鎖定相鄰的一組記錄。BDB支持頁(yè)級(jí)鎖。

開銷和加鎖時(shí)間界于表鎖和行鎖之間;會(huì)出現(xiàn)死鎖;鎖定粒度界于表鎖和行鎖之間,并發(fā)度一般

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • MySQL鎖機(jī)制與用法分析
  • MySQL InnoDB中的鎖機(jī)制深入講解
  • mysql中的鎖機(jī)制深入講解
  • MySQL隔離級(jí)別和鎖機(jī)制的深入講解
  • mysql中鎖機(jī)制的最全面講解

標(biāo)簽:銅川 仙桃 崇左 蘭州 湘潭 黃山 湖南 衡水

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL數(shù)據(jù)庫(kù)鎖機(jī)制原理解析》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    南宁市| 龙里县| 兴国县| 道孚县| 常宁市| 白朗县| 中江县| 吉林市| 翁牛特旗| 静海县| 辰溪县| 滨州市| 兰坪| 招远市| 富源县| 万荣县| 揭阳市| 永胜县| 循化| 姜堰市| 冷水江市| 松桃| 栾城县| 凌源市| 镶黄旗| 三河市| 崇文区| 南华县| 丹凤县| 沙洋县| 北安市| 斗六市| 泉州市| 兰州市| 兴业县| 遵化市| 田阳县| 腾冲县| 昂仁县| 成安县| 通榆县|