巷尾的酒吧

            BlogJava :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
            64 Posts :: 0 Stories :: 5 Comments :: 0 Trackbacks

          數(shù)據(jù)庫(kù)系統(tǒng)中事務(wù)的ACID原則是什么啊??
          事務(wù)的原子性、一致性、獨(dú)立性及持久性
          事務(wù)的原子性是指一個(gè)事務(wù)要么全部執(zhí)行,要么不執(zhí)行.也就是說(shuō)一個(gè)事務(wù)不可能只執(zhí)行了一半就停止了.比如你從取款機(jī)取錢,這個(gè)事務(wù)可以分成兩個(gè)步驟:1劃卡,2出錢.不可能劃了卡,而錢卻沒(méi)出來(lái).這兩步必須同時(shí)完成.要么就不完成.
          事務(wù)的一致性是指事務(wù)的運(yùn)行并不改變數(shù)據(jù)庫(kù)中數(shù)據(jù)的一致性.例如,完整性約束了a+b=10,一個(gè)事務(wù)改變了a,那么b也應(yīng)該隨之改變.
          事務(wù)的獨(dú)立性是指兩個(gè)以上的事務(wù)不會(huì)出現(xiàn)交錯(cuò)執(zhí)行的狀態(tài).因?yàn)檫@樣可能會(huì)導(dǎo)致數(shù)據(jù)不一致.
          事務(wù)的持久性是指事務(wù)運(yùn)行成功以后,就系統(tǒng)的更新是永久的.不會(huì)無(wú)緣無(wú)故的回滾.

          spring事務(wù)傳播屬性和隔離級(jí)別
          1 事務(wù)的傳播屬性(Propagation) 

          1) REQUIRED ,這個(gè)是默認(rèn)的屬性 
          Support a current transaction, create a new one if none exists. 
          如果存在一個(gè)事務(wù),則支持當(dāng)前事務(wù)。如果沒(méi)有事務(wù)則開(kāi)啟一個(gè)新的事務(wù)。 
          被設(shè)置成這個(gè)級(jí)別時(shí),會(huì)為每一個(gè)被調(diào)用的方法創(chuàng)建一個(gè)邏輯事務(wù)域。如果前面的方法已經(jīng)創(chuàng)建了事務(wù),那么后面的方法支持當(dāng)前的事務(wù),如果當(dāng)前沒(méi)有事務(wù)會(huì)重新建立事務(wù)。 
          如圖所示: 

          2) MANDATORY 
          Support a current transaction, throw an exception if none exists.支持當(dāng)前事務(wù),如果當(dāng)前沒(méi)有事務(wù),就拋出異常。 

          3) NEVER 
          Execute non-transactionally, throw an exception if a transaction exists. 
          以非事務(wù)方式執(zhí)行,如果當(dāng)前存在事務(wù),則拋出異常。 

          4) NOT_SUPPORTED 
          Execute non-transactionally, suspend the current transaction if one exists. 
          以非事務(wù)方式執(zhí)行操作,如果當(dāng)前存在事務(wù),就把當(dāng)前事務(wù)掛起。 

          5) REQUIRES_NEW 
          Create a new transaction, suspend the current transaction if one exists. 
          新建事務(wù),如果當(dāng)前存在事務(wù),把當(dāng)前事務(wù)掛起。 
          如圖所示: 

          6) SUPPORTS 
          Support a current transaction, execute non-transactionally if none exists. 
          支持當(dāng)前事務(wù),如果當(dāng)前沒(méi)有事務(wù),就以非事務(wù)方式執(zhí)行。 

          7) NESTED 
          Execute within a nested transaction if a current transaction exists, behave like PROPAGATION_REQUIRED else. 
          支持當(dāng)前事務(wù),新增Savepoint點(diǎn),與當(dāng)前事務(wù)同步提交或回滾。 
          嵌套事務(wù)一個(gè)非常重要的概念就是內(nèi)層事務(wù)依賴于外層事務(wù)。外層事務(wù)失敗時(shí),會(huì)回滾內(nèi)層事務(wù)所做的動(dòng)作。而內(nèi)層事務(wù)操作失敗并不會(huì)引起外層事務(wù)的回滾。 

          8) PROPAGATION_NESTED 與PROPAGATION_REQUIRES_NEW的區(qū)別 
          它們非常 類似,都像一個(gè)嵌套事務(wù),如果不存在一個(gè)活動(dòng)的事務(wù),都會(huì)開(kāi)啟一個(gè)新的事務(wù)。使用PROPAGATION_REQUIRES_NEW時(shí),內(nèi)層事務(wù)與外層事務(wù)就像兩個(gè)獨(dú)立的事務(wù)一樣,一旦內(nèi)層事務(wù)進(jìn)行了提交后,外層事務(wù)不能對(duì)其進(jìn)行回滾。兩個(gè)事務(wù)互不影響。兩個(gè)事務(wù)不是一個(gè)真正的嵌套事務(wù)。同時(shí)它需要JTA 事務(wù)管理器的支持。 
          使用PROPAGATION_NESTED時(shí),外層事務(wù)的回滾可以引起內(nèi)層事務(wù)的回滾。而內(nèi)層事務(wù)的異常并不會(huì)導(dǎo)致外層事務(wù)的回滾,它是一個(gè)真正的嵌套事務(wù)。 

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

          1) 首先說(shuō)明一下事務(wù)并發(fā)引起的三種情況 

          i. Dirty Reads 臟讀 
          一個(gè)事務(wù)正在對(duì)數(shù)據(jù)進(jìn)行更新操作,但是更新還未提交,另一個(gè)事務(wù)這時(shí)也來(lái)操作這組數(shù)據(jù),并且讀取了前一個(gè)事務(wù)還未提交的數(shù)據(jù),而前一個(gè)事務(wù)如果操作失敗進(jìn)行了回滾,后一個(gè)事務(wù)讀取的就是錯(cuò)誤數(shù)據(jù),這樣就造成了臟讀。

          ii. Non-Repeatable Reads 不可重復(fù)讀 
          一個(gè)事務(wù)多次讀取同一數(shù)據(jù),在該事務(wù)還未結(jié)束時(shí),另一個(gè)事務(wù)也對(duì)該數(shù)據(jù)進(jìn)行了操作,而且在第一個(gè)事務(wù)兩次次讀取之間,第二個(gè)事務(wù)對(duì)數(shù)據(jù)進(jìn)行了更新,那么第一個(gè)事務(wù)前后兩次讀取到的數(shù)據(jù)是不同的,這樣就造成了不可重復(fù)讀。

          iii. Phantom Reads 幻像讀 
          第一個(gè)數(shù)據(jù)正在查詢符合某一條件的數(shù)據(jù),這時(shí),另一個(gè)事務(wù)又插入了一條符合條件的數(shù)據(jù),第一個(gè)事務(wù)在第二次查詢符合同一條件的數(shù)據(jù)時(shí),發(fā)現(xiàn)多了一條前一次查詢時(shí)沒(méi)有的數(shù)據(jù),仿佛幻覺(jué)一樣,這就是幻像讀。

          iv. 非重復(fù)度和幻像讀的區(qū)別 
          非重復(fù)讀是指同一查詢?cè)谕皇聞?wù)中多次進(jìn)行,由于其他提交事務(wù)所做的修改或刪除,每次返回不同的結(jié)果集,此時(shí)發(fā)生非重復(fù)讀。(A transaction rereads data it has previously read and finds that another committed transaction has modified or deleted the data. )

          幻像讀是指同一查詢?cè)谕皇聞?wù)中多次進(jìn)行,由于其他提交事務(wù)所做的插入操作,每次返回不同的結(jié)果集,此時(shí)發(fā)生幻像讀。(A transaction reexecutes a query returning a set of rows that satisfies a search condition and finds that another committed transaction has inserted additional rows that satisfy the condition. )

          表面上看,區(qū)別就在于非重復(fù)讀能看見(jiàn)其他事務(wù)提交的修改和刪除,而幻像能看見(jiàn)其他事務(wù)提交的插入。 

          2) DEFAULT (默認(rèn)) 
          這是一個(gè)PlatfromTransactionManager默認(rèn)的隔離級(jí)別,使用數(shù)據(jù)庫(kù)默認(rèn)的事務(wù)隔離級(jí)別.另外四個(gè)與JDBC的隔離級(jí)別相對(duì)應(yīng) 

          3) READ_UNCOMMITTED (讀未提交) 
          這是事務(wù)最低的隔離級(jí)別,它允許另外一個(gè)事務(wù)可以看到這個(gè)事務(wù)未提交的數(shù)據(jù)。這種隔離級(jí)別會(huì)產(chǎn)生臟讀,不可重復(fù)讀和幻像讀。 

          4) READ_COMMITTED (讀已提交) 
          保證一個(gè)事務(wù)修改的數(shù)據(jù)提交后才能被另外一個(gè)事務(wù)讀取。另外一個(gè)事務(wù)不能讀取該事務(wù)未提交的數(shù)據(jù)。這種事務(wù)隔離級(jí)別可以避免臟讀出現(xiàn),但是可能會(huì)出現(xiàn)不可重復(fù)讀和幻像讀。 

          5) REPEATABLE_READ (可重復(fù)讀) 
          這種事務(wù)隔離級(jí)別可以防止臟讀,不可重復(fù)讀。但是可能出現(xiàn)幻像讀。它除了保證一個(gè)事務(wù)不能讀取另一個(gè)事務(wù)未提交的數(shù)據(jù)外,還保證了不可重復(fù)讀 

          6) SERIALIZABLE(串行化) 
          這是花費(fèi)最高代價(jià)但是最可靠的事務(wù)隔離級(jí)別。事務(wù)被處理為順序執(zhí)行。除了防止臟讀,不可重復(fù)讀外,還避免了幻像讀。 

          7) 隔離級(jí)別解決事務(wù)并行引起的問(wèn)題 
          Dirty reads non-repeatable reads phantom reads 
          Serializable 不會(huì) 不會(huì) 不會(huì) 
          REPEATABLE READ 不會(huì) 不會(huì) 會(huì) 
          READ COMMITTED 不會(huì) 會(huì) 會(huì) 
          Read Uncommitted 會(huì) 會(huì) 會(huì)





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

          注:Spring中事務(wù)的隔離級(jí)別是由數(shù)據(jù)庫(kù)實(shí)現(xiàn)的


          ISOLATION_DEFAULT
              這是一個(gè)PlatfromTransactionManager默認(rèn)的隔離級(jí)別,使用數(shù)據(jù)庫(kù)默認(rèn)的事務(wù)隔離級(jí)別.另外四個(gè)與JDBC的隔離級(jí)別相對(duì)應(yīng)
          ISOLATION_READ_UNCOMMITTED 這是事務(wù)最低的隔離級(jí)別,它充許別外一個(gè)事務(wù)可以看到這個(gè)事務(wù)未提交的數(shù)據(jù)。這種隔離級(jí)別會(huì)產(chǎn)生臟讀,不可重復(fù)讀和幻像讀

          ISOLATION_READ_COMMITTED
              保證一個(gè)事務(wù)修改的數(shù)據(jù)提交后才能被另外一個(gè)事務(wù)讀取。另外一個(gè)事務(wù)不能讀取該事務(wù)未提交的數(shù)據(jù)。這種事務(wù)隔離級(jí)別可以避免臟讀出現(xiàn),但是可能會(huì)出現(xiàn)不可重復(fù)讀和幻像讀。

          ISOLATION_REPEATABLE_READ
              這種事務(wù)隔離級(jí)別可以防止臟讀,不可重復(fù)讀。但是可能出現(xiàn)幻像讀。它除了保證一個(gè)事務(wù)不能讀取另一個(gè)事務(wù)未提交的數(shù)據(jù)外,還保證了避免下面的情況產(chǎn)生(不可重復(fù)讀)。

          ISOLATION_SERIALIZABLE
              這是花費(fèi)最高代價(jià)但是最可靠的事務(wù)隔離級(jí)別。事務(wù)被處理為順序執(zhí)行。除了防止臟讀,不可重復(fù)讀外,還避免了幻像讀。

          臟讀:
              一個(gè)事務(wù)讀取到另一個(gè)事務(wù)未提交的更新數(shù)據(jù)。
          不可重復(fù)讀:
              在同一事務(wù)中,多次讀取同一數(shù)據(jù)返回的結(jié)果有所不同,即后續(xù)讀取可以讀取到另一事務(wù)已提交的更新數(shù)據(jù);相反,"可重復(fù)讀"是指在同一事務(wù)中多次讀取數(shù)據(jù)時(shí),能夠保證所讀取的數(shù)據(jù)是一樣,即后續(xù)讀取不能讀到另一事務(wù)已提交的數(shù)據(jù)。
          幻讀:
              一個(gè)事務(wù)讀取到另一事務(wù)已提交的insert數(shù)據(jù)。 

          posted on 2013-09-08 17:00 abing 閱讀(203) 評(píng)論(0)  編輯  收藏 所屬分類: spring

          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 申扎县| 衡阳市| 北川| 无为县| 奉贤区| 梓潼县| 永吉县| 高淳县| 临夏县| 崇礼县| 太保市| 曲周县| 梅河口市| 汪清县| 新绛县| 广东省| 平和县| 延吉市| 兴隆县| 绥德县| 桂东县| 新昌县| 囊谦县| 凤庆县| 宿州市| 都江堰市| 商丘市| 昌图县| 十堰市| 社会| 徐汇区| 山丹县| 龙江县| 镇安县| 曲阳县| 芦溪县| 平潭县| 惠东县| 沅陵县| 枝江市| 蓬莱市|