十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
本篇內(nèi)容介紹了“java事務(wù)、事務(wù)的隔離級(jí)別的概念是什么”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

目前創(chuàng)新互聯(lián)公司已為超過千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬空間、綿陽服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計(jì)、溫嶺網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。
事務(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)。
原子性(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)解釋為當(dāng)事務(wù)A和事務(wù)B對(duì)同一資源進(jìn)行操作時(shí),可能會(huì)遇到很多的問題。
即事務(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萬),這就是臟讀。
即同一事務(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ù)讀。
即在事務(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)生了幻覺。
為了應(yīng)對(duì)上面并發(fā)情況下出現(xiàn)的問題,事務(wù)的隔離級(jí)別就產(chǎn)生了。當(dāng)事務(wù)的隔離級(jí)別越高的時(shí)候,上面的問題就會(huì)越少,但是性能消耗也會(huì)越大。所以在實(shí)際生產(chǎn)過程中,要根據(jù)需求去確定隔離級(jí)別。
讀未提交,即能夠讀取到?jīng)]有被提交的數(shù)據(jù),所以很明顯這個(gè)級(jí)別的隔離機(jī)制無法解決臟讀、不可重復(fù)讀、幻讀中的任何一種。
已提交,即能夠讀到那些已經(jīng)提交的數(shù)據(jù),能夠防止臟讀,但是無法解決不可重復(fù)讀和幻讀的問題。
重復(fù)讀取,即在數(shù)據(jù)讀出來之后加鎖,類似”select * from XXX for update”,明確數(shù)據(jù)讀取出來就是為了更新用的,所以要加一把鎖,防止別人修改它。REPEATABLE_READ的意思也類似,讀取了一條數(shù)據(jù),這個(gè)事務(wù)不結(jié)束,別的事務(wù)就不可以改這條記錄,這樣就解決了臟讀、不可重復(fù)讀的問題,但是幻讀的問題還是無法解決。
串行化,最高的事務(wù)隔離級(jí)別,不管多少事務(wù),挨個(gè)運(yùn)行完一個(gè)事務(wù)的所有子事務(wù)之后才可以執(zhí)行另外一個(gè)事務(wù)里面的所有子事務(wù),這樣就解決了臟讀、不可重復(fù)讀和幻讀的問題了。
“java事務(wù)、事務(wù)的隔離級(jí)別的概念是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!