国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > 綜合 > 正文

SQL 數據庫中的事務

2024-07-21 02:12:58
字體:
來源:轉載
供稿:網友
11.4.1 事務的由來

使用delete 命令或update 命令對數據庫進行更新時一次只能操作一個表,這會帶來數據庫的數據不一致的問題。例如:企業取消了后勤部,需要將‘后勤部’從department表中刪除,要修改department 表,而employee 表中的部門編號與后勤部相對應的員工也應刪除。因此,兩個表都需要修,改這種修改只能通過兩條delete 語句進行。假設后勤部編號為‘1012’

第一條delete 語句修改department 表
delete from department
where dept_id = ’1012’
第二條delete 語句修改employee 表
delete from employee
where dept_id = ’1012’

    在執行第一條delete 語句后,數據庫中的數據已處于不一致的狀態,因為此時已經沒有‘后勤部’了,但employee 表中仍然保存著屬于后勤部的員工記錄。只有執行了第二條delete 語句后數據才重新處于一致狀態。但是,如果執行完第一條語句后,計算機突然出現故障,無法再繼續執行第二條delete 語句,則數據庫中的數據將處于永遠不一致的狀態。因此,必須保證這兩條delete 語句同時執行。為解決類似的問題,數據庫系統通常都引入了事務(transaction) 的概念。

11.4.2 事務的概念
    事務是一種機制,是一個操作序列,它包含了一組數據庫操作命令,所有的命令作為一個整體一起向系統提交或撤消操作請求,即要么都執行,要么都不執行。因此,事務是一個不可分割的工作邏輯單元,類似于操作系統中的原語。在數據庫系統上執行并發操作時,事務是作為最小的控制單元來使用的。

    通常在程序中用begin transaction 命令來標識一個事務的開始,用committransaction 命令標識事務結束。這兩個命令之間的所有語句被視為一體,只有執行到commit transaction 命令時,事務中對數據庫的更新操作才算確認。和begin…end 命令類似,這兩個命令也可以進行嵌套,即事務可以嵌套執行。這兩個命令的語法如下:

begin tran[saction] [transaction_name | @tran_name_variable]
commit [ tran[saction] [transaction_name | @tran_name_variable] ]
其中begin transaction 可以縮寫為begin tran、 commit transaction可以縮寫為commit tran 或commit。

  • transaction_name
    指定事務的名稱。只有前32 個字符會被系統識別。
  • @tran_name_variable
    用變量來指定事務的名稱,變量只能聲明為char、 varchar、 nchar 或 nvarchar 類型。


      

11.4.3 事務回滾
事務回滾(transaction rollback) 是指當事務中的某一語句執行失敗時,將對數據庫的操作恢復到事務執行前或某個指定位置。
事務回滾使用rollback transaction 命令,其語法如下:
rollback [tran[saction] [transaction_name | @tran_name_variable
| savepoint_name | @savepoint_variable] ]
其中savepoint_name 和@savepoint_variable 參數用于指定回滾到某一指定位置。
如果要讓事務回滾到指定位置,則需要在事務中設定保存點(save point)。所謂保存點是指定其所在位置之前的事務語句,不能回滾的語句即此語句前面的操作被視為有效。

其語法如下:
save tran[saction] {savepoint_name | @savepoint_variable}
各參數說明如下:
avepoint_name
指定保存點的名稱。同事務的名稱一樣,只有前32 個字符會被系統識別。

@savepoint_variable
用變量來指定保存點的名稱。變量只能聲明為char、 varchar、 nchar 或nvarchar 類型。



注意:如果不指定回滾的事務名稱或保存點,則rollback transaction命令會將事務回滾到事務執行前,如果事務是嵌套的、則會回滾到最靠近的begin transaction命令前。

上一篇:數據庫中的鎖

下一篇:更新數據

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 炉霍县| 延边| 阳江市| 秦安县| 临泉县| 霸州市| 澜沧| 东乌珠穆沁旗| 平江县| 海伦市| 龙口市| 老河口市| 渝北区| 祥云县| 彭山县| 海兴县| 武功县| 炉霍县| 辉南县| 白山市| 陇川县| 旬邑县| 通榆县| 普洱| 莱州市| 社旗县| 比如县| 闵行区| 会宁县| 多伦县| 长春市| 当涂县| 株洲县| 宜兰县| 万宁市| 高清| 新泰市| 德钦县| 天津市| 沁阳市| 嘉黎县|