1. 程式人生 > >Spring(十四)之事務

Spring(十四)之事務

服務 該當 str cep 成功 ati 主鍵 jos strong

事務管理

一個數據庫事務是一個被視為單一的工作單元的操作序列。這些操作應該要麽完整地執行,要麽完全不執行。事務管理是一個重要組成部分,RDBMS 面向企業應用程序,以確保數據完整性和一致性。事務的概念可以描述為具有以下四個關鍵屬性說成是 ACID

  • 原子性:事務應該當作一個單獨單元的操作,這意味著整個序列操作要麽是成功,要麽是失敗的。

  • 一致性:這表示數據庫的引用完整性的一致性,表中唯一的主鍵等。

  • 隔離性:可能同時處理很多有相同的數據集的事務,每個事務應該與其他事務隔離,以防止數據損壞。

  • 持久性:一個事務一旦完成全部操作後,這個事務的結果必須是永久性的,不能因系統故障而從數據庫中刪除。

一個真正的 RDBMS 數據庫系統將為每個事務保證所有的四個屬性。使用 SQL 發布到數據庫中的事務的簡單視圖如下:

  • 使用 begin transaction 命令開始事務。

  • 使用 SQL 查詢語句執行各種刪除、更新或插入操作。

  • 如果所有的操作都成功,則執行提交操作,否則回滾所有操作。

Spring 框架在不同的底層事務管理 APIs 的頂部提供了一個抽象層。Spring 的事務支持旨在通過添加事務能力到 POJOs 來提供給 EJB 事務一個選擇方案。Spring 支持編程式和聲明式事務管理。EJBs 需要一個應用程序服務器,但 Spring 事務管理可以在不需要應用程序服務器的情況下實現。

局部事物 vs. 全局事務

局部事務是特定於一個單一的事務資源,如一個 JDBC 連接,而全局事務可以跨多個事務資源事務,如在一個分布式系統中的事務。

局部事務管理在一個集中的計算環境中是有用的,該計算環境中應用程序組件和資源位於一個單位點,而事務管理只涉及到一個運行在一個單一機器中的本地數據管理器。局部事務更容易實現。

全局事務管理需要在分布式計算環境中,所有的資源都分布在多個系統中。在這種情況下事務管理需要同時在局部和全局範圍內進行。分布式或全局事務跨多個系統執行,它的執行需要全局事務管理系統和所有相關系統的局部數據管理人員之間的協調。

編程式 vs. 聲明式

Spring 支持兩種類型的事務管理:

  • 編程式事務管理:這意味著你在編程的幫助下有管理事務。這給了你極大的靈活性,但卻很難維護。

  • 聲明式事務管理:這意味著你從業務代碼中分離事務管理。你僅僅使用註釋或 XML 配置來管理事務。

聲明式事務管理比編程式事務管理更可取,盡管它不如編程式事務管理靈活,但它允許你通過代碼控制事務。但作為一種橫切關註點,聲明式事務管理可以使用 AOP 方法進行模塊化。Spring 支持使用 Spring AOP 框架的聲明式事務管理。

Spring 事務抽象

Spring 事務抽象的關鍵是由 org.springframework.transaction.PlatformTransactionManager 接口定義,如下所示:

public interface PlatformTransactionManager {
   TransactionStatus getTransaction(TransactionDefinition definition);
   throws TransactionException;
   void commit(TransactionStatus status) throws TransactionException;
   void rollback(TransactionStatus status) throws TransactionException;
}

技術分享圖片

TransactionDefinition 是在 Spring 中事務支持的核心接口,它的定義如下:

public interface TransactionDefinition {
   int getPropagationBehavior();
   int getIsolationLevel();
   String getName();
   int getTimeout();
   boolean isReadOnly();
}

技術分享圖片

隔離級別可能值:

技術分享圖片

傳播類型的可能值:

技術分享圖片

TransactionStatus 接口為事務代碼提供了一個簡單的方法來控制事務的執行和查詢事務狀態。

public interface TransactionStatus extends SavepointManager {
   boolean isNewTransaction();
   boolean hasSavepoint();
   void setRollbackOnly();
   boolean isRollbackOnly();
   boolean isCompleted();
}

技術分享圖片

事務為什麽這麽中重要?正如事務的四個特性那樣,原子性,一致性,隔離性,持久性,確保數據穩定、安全、真實。銀行取錢的例子足以說明。

誰都不希望,因為系統方面的事務沒有做好,特別是金融方面的軟件,如果事務沒有做好,損失將會是非常大的。對於企業而言,因為事務原因,用戶莫名其妙賬戶上多了幾個0,對於用戶當然是非常高興的一件事,但是對於企業則是毀滅性打擊。

Spring(十四)之事務