国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

MySQL事務(wù)及Spring隔離級(jí)別實(shí)現(xiàn)原理詳解

瀏覽:46日期:2023-02-06 15:01:25

1、事務(wù)具有ACID特性

原子性(atomicity):一個(gè)事務(wù)被事務(wù)不可分割的最小工作單元,要么全部提交,要么全部失敗回滾。 一致性(consistency):數(shù)據(jù)庫(kù)總是從一致性狀態(tài)到另一個(gè)一致性狀態(tài),它只包含成功事務(wù)提交的結(jié)果 隔離型(isolation):事務(wù)所做的修改在最終提交一起,對(duì)其他事務(wù)是不可見的 持久性(durability):一旦事務(wù)提交,則其所做的修改就會(huì)永久保存到數(shù)據(jù)庫(kù)中。

2、事務(wù)的隔離級(jí)別

1)隔離級(jí)別的定義與問(wèn)題

READ UNCOMMITTED(讀未提交):事務(wù)的修改,即使沒有提交,對(duì)其他事務(wù)也都是可見的。事務(wù)能夠讀取未提交的數(shù)據(jù),這種情況稱為臟讀。 READ COMMITTED(讀已提交):事務(wù)讀取已提交的數(shù)據(jù),大多數(shù)數(shù)據(jù)庫(kù)的默認(rèn)隔離級(jí)別。當(dāng)一個(gè)事務(wù)在執(zhí)行過(guò)程中,數(shù)據(jù)被另外一個(gè)事務(wù)修改,造成本次事務(wù)前后讀取的信息不一樣,這種情況稱為不可重復(fù)讀。 PEPEATABLE READ(可重復(fù)讀):這個(gè)級(jí)別是MySQL的默認(rèn)隔離級(jí)別,它解決了臟讀的問(wèn)題,同時(shí)也保證了同一個(gè)事務(wù)多次讀取同樣的記錄是一致的,但這個(gè)級(jí)別還是會(huì)出現(xiàn)幻讀的情況。幻讀是指當(dāng)一個(gè)事務(wù)A讀取某一個(gè)范圍的數(shù)據(jù)時(shí),另一個(gè)事務(wù)B在這個(gè)范圍插入行,A事務(wù)再次讀取這個(gè)范圍的數(shù)據(jù)時(shí),會(huì)產(chǎn)生幻行。特別說(shuō)明:InnoDB和XtraDB存儲(chǔ)引擎通過(guò)多版本并發(fā)控制(MVCC,Multiversion Concurrency Control)解決了幻讀問(wèn)題,它使用間隙鎖(next-key locking)鎖定查詢涉及的行和索引中的間隙,防止幻影行的插入。 SERIALIZABLE(可串行化):這個(gè)事務(wù)是最高的隔離級(jí)別,它強(qiáng)制事務(wù)串行執(zhí)行,避免了幻讀問(wèn)題。簡(jiǎn)單來(lái)說(shuō),SERIALIZABLE會(huì)在讀取的每一行數(shù)據(jù)上都加鎖,所以可能會(huì)導(dǎo)致大量的超時(shí)和鎖競(jìng)爭(zhēng)

隔離級(jí)別 臟讀可能性 不可重復(fù)度可能性 幻讀可能性 加鎖讀 READ UNCONMITED Yes Yes Yes No RED COMMITED No Yes Yes No REPEATABLE READ No No Yes No SERIALIZABLE No No No Yes

2)如果查看修改和MySQL的隔離級(jí)別

show variables like ’tx_isolation’; # 查看隔離級(jí)別,MySQL8以前show variables like ’transaction_isolation’; # 查看隔離級(jí)別,MySQL8set global transaction_isolation=’READ-COMMITTED’; // 設(shè)置隔離級(jí)別,閥域READ-UNCOMMITTED、READ-COMMITTED、REPEATABLE-READ、SERIALIZABLE

事務(wù)的隔離級(jí)別可以是Session層的,我們可以對(duì)不同的Session設(shè)置不同級(jí)別:

set session transaction isolation level read uncommitted;set session transaction isolation level read committed;set session transaction isolation level repeatable read;set session transaction isolation level serializable;

3)Spring事務(wù)隔離級(jí)別

Spring事務(wù)默認(rèn)使用數(shù)據(jù)庫(kù)的隔離級(jí)別,可以通過(guò)注解@Transactional中的isolation參數(shù)調(diào)整Session級(jí)的隔離級(jí)別。隔離級(jí)別是會(huì)話級(jí)別的,JDBC的java.sql.Connection接口支持隔離級(jí)別的設(shè)置。

MySQL事務(wù)及Spring隔離級(jí)別實(shí)現(xiàn)原理詳解

Spring在開啟事務(wù)時(shí)(DataSourceTransactionManager.doBegin),根據(jù)注解配置,對(duì)Connection的隔離級(jí)別進(jìn)行設(shè)置:

MySQL事務(wù)及Spring隔離級(jí)別實(shí)現(xiàn)原理詳解

MySQL驅(qū)動(dòng)com.mysql.cj.jdbc.ConnectionImpl執(zhí)行SQL語(yǔ)句調(diào)整會(huì)話級(jí)的隔離級(jí)別

MySQL事務(wù)及Spring隔離級(jí)別實(shí)現(xiàn)原理詳解

3、死鎖

死鎖是指兩個(gè)或多個(gè)事務(wù)在同一資源上相互占用,并請(qǐng)求鎖定對(duì)方占用的資源,從而導(dǎo)致惡性循環(huán)。死鎖示例:

# 事務(wù)一start transaction;update account set money=10 where id=1;update account set money=20 where id=2;commit;# 事務(wù)二start transaction;update account set money=10 where id=2;update account set money=20 where id=1;commit;

假設(shè)碰巧,事務(wù)一和事務(wù)二同時(shí)執(zhí)行完第一個(gè)update語(yǔ)句,接著準(zhǔn)備執(zhí)行第二條update語(yǔ)句,卻發(fā)現(xiàn)記錄已被對(duì)方鎖定,然后2個(gè)事務(wù)都等待對(duì)方釋放資源,同時(shí)持有對(duì)方需要的鎖,這樣就會(huì)出現(xiàn)死循環(huán)。

為了避免死鎖問(wèn)題,數(shù)據(jù)庫(kù)實(shí)現(xiàn)了各種死鎖檢測(cè)和死鎖超長(zhǎng)機(jī)制,InnoDB處理死鎖的方式是:將持有最少行級(jí)排他鎖的事務(wù)進(jìn)行回滾。

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

標(biāo)簽: Spring
相關(guān)文章:
主站蜘蛛池模板: 睢宁县| 雷波县| 金溪县| 康定县| 富川| 易门县| 龙山县| 格尔木市| 新源县| 凤凰县| 浏阳市| 保康县| 娄烦县| 汝阳县| 全椒县| 同江市| 镶黄旗| 日照市| 永嘉县| 四会市| 喀喇沁旗| 青州市| 九龙城区| 婺源县| 长宁区| 佛坪县| 商都县| 晋中市| 保山市| 金平| 唐山市| 霍林郭勒市| 榆社县| 彭水| 高密市| 清远市| 石楼县| 鹤山市| 镇江市| 栖霞市| 万盛区|