什么是事務(wù)踢代?
??事務(wù)盲憎,即數(shù)據(jù)庫事務(wù)。是數(shù)據(jù)庫管理系統(tǒng)執(zhí)行過程中的一個(gè)邏輯單位奸鬓,由一個(gè)有限的數(shù)據(jù)庫操作序列構(gòu)成焙畔。
??通常掸读,事務(wù)的正確執(zhí)行會(huì)使數(shù)據(jù)庫從一種狀態(tài)轉(zhuǎn)換為另一種狀態(tài)串远。
事務(wù)的特性(ACID原則)
原子性(atomicity) 即不可分割性,事務(wù)要么全執(zhí)行儿惫、要么全不執(zhí)行澡罚。
一致性(consistency) 事務(wù)的執(zhí)行使得數(shù)據(jù)庫從一種正確狀態(tài)轉(zhuǎn)換成另外一種正確狀態(tài)。
隔離性(isolation) 在事務(wù)正確提交之前肾请,不允許把事務(wù)對(duì)該數(shù)據(jù)的改變提供給任何其他事務(wù)留搔。
持久性(durability) 事務(wù)正確提交之后,其結(jié)果將永遠(yuǎn)保存在數(shù)據(jù)庫之中铛铁。
并發(fā)狀態(tài)下事務(wù)會(huì)產(chǎn)生的問題
??并發(fā)狀態(tài)解釋為當(dāng)事務(wù)A和事務(wù)B對(duì)同一資源進(jìn)行操作時(shí)隔显,可能會(huì)遇到很多的問題。
臟讀(針對(duì)未提交數(shù)據(jù))
??即事務(wù)A讀到了事務(wù)B還沒有提交的數(shù)據(jù)饵逐。如果事務(wù)A對(duì)數(shù)據(jù)進(jìn)行了更新括眠,但是事務(wù)A并沒有提交,但是事務(wù)B這個(gè)時(shí)候看到了事務(wù)A沒有提交的更新倍权。當(dāng)事務(wù)A進(jìn)行了回滾掷豺,那么剛剛事務(wù)B看到的數(shù)據(jù)就是臟數(shù)據(jù)。也就是臟讀薄声。
??例子:
??A 給 B 轉(zhuǎn)了100萬当船,但是 A 還沒有提交,此時(shí) B 查詢自己賬戶默辨,多了100萬德频。然后 A 發(fā)現(xiàn)轉(zhuǎn)錯(cuò)人了,回滾了事物缩幸。然后 B 100萬就沒了壹置。在這個(gè)過程中 B 查到了沒有提交的數(shù)據(jù)(多出的100萬)档叔,這就是臟讀。
不可重復(fù)讀(在一個(gè)事務(wù)里面讀取了兩次某個(gè)數(shù)據(jù)蒸绩,讀出來的數(shù)據(jù)不一致衙四,針對(duì)修改操作)
即同一事務(wù)在事務(wù)執(zhí)行過程中對(duì)同一個(gè)數(shù)據(jù)進(jìn)行了多次讀取,但是每一次讀取的數(shù)據(jù)結(jié)果都不相同患亿。原因是在兩次讀取間隔传蹈,數(shù)據(jù)別其他人修改了,導(dǎo)致了統(tǒng)一事務(wù)兩次讀取結(jié)果不一致步藕。
??例子:
A 查詢銀行余額為100萬惦界,B 這個(gè)時(shí)候取走了50萬,此時(shí)余額變成了50萬咙冗,A 再一次查詢余額基矮,變成了50萬。對(duì) A 而言兩次結(jié)果不一致就是不可重復(fù)讀伦腐。
幻讀(在一個(gè)事務(wù)里面的操作中發(fā)現(xiàn)了未被操作的數(shù)據(jù)泄伪,針對(duì)增刪操作)
即在事務(wù) A 多次讀取數(shù)據(jù)集的過程中中,事務(wù) B 對(duì)數(shù)據(jù)進(jìn)行了新增操作或者刪除操作立润,導(dǎo)致事務(wù) A 多次讀取的數(shù)據(jù)集不一致狂窑。
??例子:
A 修改當(dāng)前公司所有職員信息的時(shí)候,B 向其中插入了一個(gè)新的職員桑腮,這個(gè)時(shí)候 A 提交的時(shí)候發(fā)現(xiàn)了一個(gè)自己沒有修改過的職員的信息泉哈,對(duì) A 而言就像是產(chǎn)生了幻覺。
事務(wù)的隔離級(jí)別
為了應(yīng)對(duì)上面并發(fā)情況下出現(xiàn)的問題破讨,事務(wù)的隔離級(jí)別就產(chǎn)生了丛晦。當(dāng)事務(wù)的隔離級(jí)別越高的時(shí)候,上面的問題就會(huì)越少提陶,但是性能消耗也會(huì)越大烫沙。所以在實(shí)際生產(chǎn)過程中,要根據(jù)需求去確定隔離級(jí)別搁骑。
四種隔離級(jí)
READ_UNCOMMITTED
讀未提交斧吐,即能夠讀取到?jīng)]有被提交的數(shù)據(jù),所以很明顯這個(gè)級(jí)別的隔離機(jī)制無法解決臟讀仲器、不可重復(fù)讀煤率、幻讀中的任何一種。
READ_COMMITED
已提交乏冀,即能夠讀到那些已經(jīng)提交的數(shù)據(jù)蝶糯,能夠防止臟讀,但是無法解決不可重復(fù)讀和幻讀的問題辆沦。
REPEATABLE_READ
重復(fù)讀取昼捍,即在數(shù)據(jù)讀出來之后加鎖识虚,類似"select * from XXX for update",明確數(shù)據(jù)讀取出來就是為了更新用的妒茬,所以要加一把鎖担锤,防止別人修改它。REPEATABLE_READ的意思也類似乍钻,讀取了一條數(shù)據(jù)肛循,這個(gè)事務(wù)不結(jié)束,別的事務(wù)就不可以改這條記錄银择,這樣就解決了臟讀多糠、不可重復(fù)讀的問題,但是幻讀的問題還是無法解決浩考。
SERLALIZABLE
串行化夹孔,最高的事務(wù)隔離級(jí)別,不管多少事務(wù)析孽,挨個(gè)運(yùn)行完一個(gè)事務(wù)的所有子事務(wù)之后才可以執(zhí)行另外一個(gè)事務(wù)里面的所有子事務(wù)搭伤,這樣就解決了臟讀、不可重復(fù)讀和幻讀的問題了绿淋。
歡迎工作一到五年的Java工程師朋友們加入JavaQQ群:219571750闷畸,群內(nèi)提供免費(fèi)的Java架構(gòu)學(xué)習(xí)資料(里面有高可用尝盼、高并發(fā)吞滞、高性能及分布式、Jvm性能調(diào)優(yōu)盾沫、Spring源碼裁赠,MyBatis,Netty,Redis,Kafka,Mysql,Zookeeper,Tomcat,Docker,Dubbo,Nginx等多個(gè)知識(shí)點(diǎn)的架構(gòu)資料)合理利用自己每一分每一秒的時(shí)間來學(xué)習(xí)提升自己赴精,不要再用"沒有時(shí)間“來掩飾自己思想上的懶惰佩捞!趁年輕,使勁拼蕾哟,給未來的自己一個(gè)交代一忱!