日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

事务的四大属性ACID即事务的原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability.。...

發布時間:2024/1/8 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 事务的四大属性ACID即事务的原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability.。... 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

事務的四大屬性ACID即事務的原子性(Atomicity)、一致性(Consistency)、隔離性(Isolation)、持久性(Durability.。

?

?

? 原子性(Atomicity)
原子性是指事務是一個不可分割的工作單位,事務中的操作要么都發生,要么都不發生。?

一致性(Consistency)
事務必須使數據庫從一個一致性狀態變換到另外一個一致性狀態。

隔離性(Isolation)
事務的隔離性是多個用戶并發訪問數據庫時,數據庫為每一個用戶開啟的事務,不能被其他事務的操作數據所干擾,多個并發事務之間要相互隔離。

持久性(Durability)
持久性是指一個事務一旦被提交,它對數據庫中數據的改變就是永久性的,接下來即使數據庫發生故障也不應該對其有任何影響。

?

事務的隔離級別

l???????多個線程開啟各自事務操作數據庫中數據時,數據庫系統要負責隔離操作,以保證各個線程在獲取數據時的準確性。

l??????如果不考慮隔離性,可能會引發如下問題:

?

?

1、? 臟讀:

?????????指一個事務讀取了另外一個事務未提交的數據。

這是非常危險的,假設A向B轉帳100元,對應sql語句如下所示

1.updateaccount set money=money+100 while name=‘b’;???

2.updateaccount set money=money-100 while name=‘a’;

當第1條sql執行完,第2條還沒執行(A未提交時),如果此時B查詢自己的帳戶,就會發現自己多了100元錢。如果A等B走后再回滾,B就會損失100元。

?

2、不可重復讀:

?????????在一個事務內讀取表中的某一行數據,多次讀取結果不同。

例如銀行想查詢A帳戶余額,第一次查詢A帳戶為200元,此時A向帳戶存了100元并提交了,銀行接著又進行了一次查詢,此時A帳戶為300元了。銀行兩次查詢不一致,可能就會很困惑,不知道哪次查詢是準的。

?

?????????和臟讀的區別是,臟讀是讀取前一事務未提交的臟數據,不可重復讀是重新讀取了前一事務已提交的數據。

?

?????????很多人認為這種情況就對了,無須困惑,當然是后面的為準。我們可以考慮這樣一種情況,比如銀行程序需要將查詢結果分別輸出到電腦 屏幕和寫到文件中,結果在一個事務中針對輸出的目的地,進行的兩次查詢不一致,導致文件和屏幕中的結果不一致,銀行工作人員就不知道以哪個為準了。

?

?3、虛讀(幻讀)

?????????是指在一個事務內讀取到了別的事務插入的數據,導致前后讀取不一致。

?????????如丙存款100元未提交,這時銀行做報表統計account表中所有用戶的總額為500元,然后丙提交了,這時銀行再統計發現帳戶為600元了,造成虛讀同樣會使銀行不知所措,到底以哪個為準。

?

?????因此,在特定的情況下,為事務設定相應的隔離級別是十分必要的。

???????事務的隔離級別的設定方法如下:

??????? Serializable:可避免臟讀、不可重復讀、虛讀情況的發生。(串行化)(序列化)

?????????Repeatable read:可避免臟讀、不可重復讀情況的發生。(可重復讀)

?????????Read committed:可避免臟讀情況發生(讀已提交)。

?????????Read uncommitted:最低級別,以上情況均無法保證。(讀未提交)

set?? transaction isolation level 設置事務隔離級別

select@@tx_isolation????? 查詢當前事務隔離級別

轉載于:https://www.cnblogs.com/1995hxt/p/5550855.html

總結

以上是生活随笔為你收集整理的事务的四大属性ACID即事务的原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)、持久性(Durability.。...的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。