国产探花免费观看_亚洲丰满少妇自慰呻吟_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命令前。

上一篇:數據庫中的鎖

下一篇:更新數據

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 漯河市| 益阳市| 广水市| 辽阳市| 黎平县| 白沙| 崇礼县| 凤冈县| 米泉市| 尤溪县| 尚志市| 蓬莱市| 铜陵市| 绵阳市| 武义县| 都兰县| 仁化县| 饶平县| 璧山县| 莲花县| 横山县| 淄博市| 工布江达县| 马公市| 庄浪县| 浙江省| 淮阳县| 博客| 宝山区| 湟源县| 固镇县| 龙井市| 津南区| 栖霞市| 达拉特旗| 临沭县| 甘肃省| 青铜峡市| 鹤峰县| 义马市| 六安市|