SQL—— 事務


 SQL 事務:

 

1.  定義: 

事務是作為單個邏輯單元執行的一系列操作。 多個操作作為一個整體向系統提交,要么執行、要么都不執行,事務是一個不可分割的工作邏輯單元。這特別適用於多用戶同時操作的數據通信系統。例如:訂票、銀行、保險公司以及證券交易系統等。

 

2. 事務必須具備的特性: 

   1) 原子性:  Atomicity  :事務是一個完整的操作, 個元素是不可再分的。事務中所以元素必須作為一個整體提交或回滾。如果十五中任何元素失敗,則整個事務將失敗。

   2)一致性: Consistency: 當事務完成時,數據必須處於一致狀態。

   3)隔離性: Lsolation: 對數據進行修改的所有並發事務是彼此隔離的,它不以任何方式依賴或影響其他事務。

   4)持久性: 不管系統是否發生了故障,事務處理的結果都是永久性的。

 

3. 如何執行事務:

    1)開始事務:  begin  transaction

    2)  提交事務: commit transaction

    3)  回滾事務: rollback transaction

 

4. 事務分類

    1) 顯示事務: 用begin transaction 明確指定事務的開始

    2) 隱式事務: 通過設置 set implicit_transactions on 語句,將隱式事務模式設置為打開。當以隱式事務模式操作時,SQlServer將在提交或回滾事務后自動啟動新事務。不需要描述每個事務的開始,只要提交或回滾每個事務即可。

    3) 自動提交事務: 這是SQL Server的默認模式,它將每條單獨的T-SQL語句視為一個事務。如果成功執行,則自動提交。如果錯誤,則自動回滾。

 

5. 示例

   XXXXXX  業務邏輯

 

  begin transaction  --開始事務

   declare @error  int  --定義變量,累積事務執行過程中的錯誤

   set @error = 0

   ----- 執行語句1

    set  @error = @error + @@error  --累積錯誤

   ---- 執行語句2

    set  @error = @error + @@error  --累積錯誤

   ------

   

   --判斷

   if  @error <> 0  --有誤

     begin

    print  '回滾事務'

           rollback  transaction

     end

   else  

     begin

    print  '提交事務'

           commit transaction

     end

  

 

   

    


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM