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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

数据库的事务学习

發布時間:2023/12/3 数据库 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 数据库的事务学习 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 事務四大特征
  • 多事務并發存在的問題
  • 事務隔離級別
  • 查詢數據庫的隔離級別
  • 設置數據庫隔離級別

1.事務里面的語句出錯時并不會主動回滾,需要用戶主動執行回滾指令
2.事務開始后,如果沒有主動執行回滾或者提交指令,事務始終在執行中
3.事務執行中,涉及到的表被鎖定,其它會話可以查詢,但是不能修改
4.執行回滾指令,事務中的執行計劃被舍棄,事務結束
5.執行提交指令,事務中的執行計劃被切實執行,而且這個切實執行還不可能報錯,事務結束

事務四大特征

1.原子性,事務是不可分割的最小操作單位,要么同時成功,要么同時失敗

2.持久性,一個事務一旦被提交了,那么對數據庫中的數據的改變就是永久性的,即便是在數據庫系統遇到故障的情況下也不會丟失提交事務的數據

3.隔離性,隔離性是當多個用戶并發訪問數據庫時,比如操作同一張表時,數據庫為每一個用戶開啟的事務,不能被其他事務的操作所干擾,多個并發事務之間要相互隔離。

4.一致性,事務執行前后的數據完整性保持一致。拿轉賬來說,假設用戶A和用戶B兩者的錢加起來一共是5000,那么不管A和B之間如何轉賬,轉幾次賬,事務結束后兩個用戶的錢相加起來應該還得是5000,這就是事務的一致性。

多事務并發存在的問題

1.臟讀,一個事務,讀取到另一個事務中沒有提交的數據

2.不可重復讀(虛讀) ,在同一個事務中,兩次讀取到的數據不一樣

3.幻讀

示例(1):
事務 T 查詢某記錄是否存在,查詢結果是不存在,于是插入這條記錄,但執行插入語句時發現此記錄已存在(其它事務插入了數據),無法插入,此時就發生了幻讀。

示例(2):
事務 T1 將表中所有行的字段 A 的值從 1 修改為 2,這時事務 T2 又對這個表插入了一行數據,而且這行數據的字段 A 的值就是 1 并且提交給數據庫。如果事務 T1 再查看剛剛修改的數據,會發現還有一行沒有修改,其實這行數據事務 T2 添加進去的,就好像產生幻覺一樣,這就是發生了幻讀。

事務隔離級別

1.Read Uncommitted,表示讀取未提交的,效率最高,但是安全級別最低,會產生臟讀、不可重復讀、幻讀三種問題

2.Read Committed,讀取已提交的,效率其次,安全級別稍好,不會產生臟讀問題,但是會產生不可重復讀和幻讀兩種問題。Oracle 默認此級別

3.Repeatable Read,可重復讀,效率還行,安全級別不錯,不會產生臟讀和不可重復讀的問題,但是會產生幻讀問題。MySQL 默認此級別

4.Serializable,串行化,效率比較低,安全級別最高,不會產生任何問題。原因:某個事務對某個表的數據進行了修改會加表級排他鎖;如果查詢某個表的數據則會加表級共享鎖

查詢數據庫的隔離級別

mysql> select @@tx_isolation; +-----------------+ | @@tx_isolation | +-----------------+ | REPEATABLE-READ | +-----------------+ 1 row in set, 1 warning (0.00 sec)

如果是 macOS,事務隔離級別的系統變量是:

mysql> select @@transaction_isolation; +-------------------------+ | @@transaction_isolation | +-------------------------+ | SERIALIZABLE | +-------------------------+ 1 row in set (0.00 sec)

設置數據庫隔離級別

# 設置全局級別的 set global transaction isolation level repeatable-read # 設置會話級別的 set session transaction isolation level repeatable-read 創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎

總結

以上是生活随笔為你收集整理的数据库的事务学习的全部內容,希望文章能夠幫你解決所遇到的問題。

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