久久精品人人爽,华人av在线,亚洲性视频网站,欧美专区一二三

SQL中的ACID指的是什么

146次閱讀
沒有評論

共計 1238 個字符,預計需要花費 4 分鐘才能閱讀完成。

本篇內容介紹了“SQL 中的 ACID 指的是什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓丸趣 TV 小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

WAL 的中心思想是對數據文件的修改(它們是表和索引的載體)必須是只能發生在這些修改已經記錄了日志之后,也就是說,在日志記錄沖刷到永久存儲器之后。

如果我們遵循這個過程,那么我們就不需要在每次事務提交的時候都把數據頁沖刷到磁盤,因為我們知道在出現崩潰的情況下,

我們可以用日志來恢復數據庫:任何尚未附加到數據頁的記錄都將先從日志記錄中重做(這叫向前滾動恢復,也叫做 REDO)然后那些未提交的事務做的修改將被從數據頁中刪除(這叫向后滾動恢復 -UNDO)。

1、一致性:

一個事務可以封裝狀態改變(除非它是一個只讀的)。

事務必須始終保持系統處于一致的狀態,不管在任何給定的時間并發事務有多少。

也就是說:如果事務是并發多個,系統也必須如同串行事務一樣操作。

其主要特征是保護性和不變性 (PreservinganInvariant),以轉賬案例為例,假設有五個賬戶,每個賬戶余額是 100 元,那么五個賬戶總額是 500 元

如果在這個 5 個賬戶之間同時發生多個轉賬,無論并發多少個,比如在 A 與 B 賬戶之間轉賬 5 元,在 C 與 D 賬戶之間轉賬 10 元,在 B 與 E 之間轉賬 15 元,五個賬戶總額也應該還是 500 元,這就是保護性和不變性。

2、原子性:

整個事務中的所有操作,要么全部完成,要么全部不完成,不可能停滯在中間某個環節。

事務在執行過程中發生錯誤,會被回滾(Rollback)到事務開始前的狀態,就像這個事務從來沒有執行過一樣。

3、持久性

在事務提交完成以后,該事務對數據庫所做的更改便持久的保存在數據庫之中,永久保存下來,并不會被回滾。

4、隔離性

隔離狀態執行事務,使它們好像是系統在給定時間內執行的唯一操作。

如果有兩個事務,運行在相同的時間內,執行相同的功能,事務的隔離性將確保每一事務在系統中認為只有該事務在使用系統。

這種屬性有時稱為串行化,為了防止事務操作間的混淆,必須串行化或序列化請求,使得在同一時間僅有一個請求用于同一數據。

說明

由于一項操作通常會包含許多子操作,而這些子操作可能會因為硬件的損壞或其他因素產生問題,要正確實現 ACID 并不容易。

ACID 建議數據庫將所有需要更新以及修改的資料一次操作完畢,但實際上并不可行。

目前主要有兩種方式實現 ACID:第一種是 Writeaheadlogging,也就是日志式的方式 (現代數據庫均基于這種方式)。第二種是 Shadowpaging。

相對于 WAL(writeaheadlogging)技術,shadowpaging 技術實現起來比較簡單,消除了寫日志記錄的開銷恢復的速度也快 (不需要 redo 和 undo)。

“SQL 中的 ACID 指的是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注丸趣 TV 網站,丸趣 TV 小編將為大家輸出更多高質量的實用文章!

正文完
 
丸趣
版權聲明:本站原創文章,由 丸趣 2023-07-28發表,共計1238字。
轉載說明:除特殊說明外本站除技術相關以外文章皆由網絡搜集發布,轉載請注明出處。
評論(沒有評論)
主站蜘蛛池模板: 洛隆县| 亳州市| 潮州市| 海盐县| 仁化县| 咸阳市| 沧源| 达拉特旗| 元氏县| 西和县| 高密市| 奉化市| 连山| 油尖旺区| 抚宁县| 昌乐县| 且末县| 新津县| 三亚市| 唐山市| 栖霞市| 柳江县| 德惠市| 灌阳县| 康平县| 南岸区| 合阳县| 建德市| 无棣县| 仪陇县| 安化县| 江油市| 工布江达县| 东至县| 翁牛特旗| 宜城市| 惠东县| 怀集县| 通化县| 轮台县| 金溪县|