事務(wù)的4個(gè)基本特性(ACID):
1. Atomic(原子性):事務(wù)中包含的操作被看作一個(gè)邏輯單元,這個(gè)邏輯單元中的操作要么全部成功,要么全部失敗。
2. Consistency(一致性):只有合法的數據可以被寫(xiě)入數據庫,否則事務(wù)應該將其回滾到最初狀態(tài)。
3. Isolation(隔離性):事務(wù)允許多個(gè)用戶(hù)對同一個(gè)數據的并發(fā)訪(fǎng)問(wèn),而不破壞數據的正確性和完整性。同時(shí),并行事務(wù)的修改必須與其他并行事務(wù)的修改相互獨立。
4. Durability(持久性):事務(wù)結束后,事務(wù)處理的結果必須能夠得到固化。
數據庫操作過(guò)程中可能出現的3種不確定情況:
1. 臟讀?。―irty Reads):一個(gè)事務(wù)讀取了另一個(gè)并行事務(wù)未提交的數據。
2. 不可重復讀?。∟on-repeatable Reads):一個(gè)事務(wù)再次讀取之前的數據時(shí),得到的數據不一致,被另一個(gè)已提交的事務(wù)修改。
3. 虛讀(Phantom Reads):一個(gè)事務(wù)重新執行一個(gè)查詢(xún),返回的記錄中包含了因為其他最近提交的事務(wù)而產(chǎn)生的新記錄。
標準SQL規范中,為了避免上面3種情況的出現,定義了4個(gè)事務(wù)隔離等級:
1. Read Uncommitted:最低等級的事務(wù)隔離,僅僅保證了讀取過(guò)程中不會(huì )讀取到非法數據。上訴3種不確定情況均有可能發(fā)生。
2. Read Committed:大多數主流數據庫的默認事務(wù)等級,保證了一個(gè)事務(wù)不會(huì )讀到另一個(gè)并行事務(wù)已修改但未提交的數據,避免了“臟讀取”。該級別適用于大多數系統。
3. Repeatable Read:保證了一個(gè)事務(wù)不會(huì )修改已經(jīng)由另一個(gè)事務(wù)讀取但未提交(回滾)的數據。避免了“臟讀取”和“不可重復讀取”的情況,但是帶來(lái)了更多的性能損失。
4. Serializable:最高等級的事務(wù)隔離,上面3種不確定情況都將被規避。這個(gè)級別將模擬事務(wù)的串行執行。
Hibernate將事務(wù)管理委托給底層的JDBC或者JTA,默認是基于JDBC Transaction的。
Hibernate支持“悲觀(guān)鎖(Pessimistic Locking)”和“樂(lè )觀(guān)鎖(Optimistic Locking)”。
悲觀(guān)鎖對數據被外界修改持保守態(tài)度,因此,在整個(gè)數據處理過(guò)程中,將數據處于鎖定狀態(tài)。悲觀(guān)鎖的實(shí)現,往往依靠數據庫提供的鎖機制。Hibernate通過(guò)使用數據庫的for update子句實(shí)現了悲觀(guān)鎖機制。Hibernate的加鎖模式有:
1. LockMode.NONE:無(wú)鎖機制
2. LockMode.WRITE:Hibernate在Insert和Update記錄的時(shí)候會(huì )自動(dòng)獲取
3. LockMode.READ:Hibernate在讀取記錄的時(shí)候會(huì )自動(dòng)獲取
4. LockMode.UPGRADE:利用數據庫的for update子句加鎖
5. LockMode.UPGRADE_NOWAIT:Oracle的特定實(shí)現,利用Oracle的for update nowait子句實(shí)現加鎖
樂(lè )觀(guān)鎖大多是基于數據版本(Version)記錄機制實(shí)現。Hibernate在其數據訪(fǎng)問(wèn)引擎中內置了樂(lè )觀(guān)鎖實(shí)現,可以通過(guò)class描述符的 optimistic-lock屬性結合version描述符指定。optimistic-lock屬性有如下可選取值:
1. none:無(wú)樂(lè )觀(guān)鎖
2. version:通過(guò)版本機制實(shí)現樂(lè )觀(guān)鎖
3. dirty:通過(guò)檢查發(fā)生變動(dòng)過(guò)的屬性實(shí)現樂(lè )觀(guān)鎖
4. all:通過(guò)檢查所有屬性實(shí)現樂(lè )觀(guān)鎖
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請
點(diǎn)擊舉報。