<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
事務就是一組DML語句組成,這些語句在邏輯上存在相關性,這一組DML語句要麼全部成功,要麼全部失敗,是一個整體。MySQL提供一種機制,保證我們達到這樣的效果。事務還規定不同的使用者端看到的資料是不相同的。
事務就是要做的或所做的事情,主要用於處理操作量大,複雜度高的資料。假設一種場景:你畢業了,學校的教務系統後臺 MySQL 中,不在需要你的資料,要刪除你的所有資訊(一般不會:) ), 那麼要刪除你的基本資訊(姓名,電話,籍貫等)的同時,也刪除和你有關的其他資訊,比如:你的各科成績,你在校表現,甚至你在論壇發過的文章等。這樣,就需要多條 MySQL 語句構成,那麼所有這些操作合起來,就構成了一個事務。
正如我們上面所說,一個 MySQL 資料庫,可不止你一個事務在執行,同一時刻,甚至有大量的請求被包裝成事務,在向 MySQL 伺服器發起事務處理請求。而每條事務至少一條 SQL ,最多很多 SQL ,這樣如果大家都存取同樣的表資料,在不加保護的情況,就絕對會出現問題。甚至,因為事務由多條 SQL 構成,那麼,也會存在執行到一半出錯或者不想再執行的情況,那麼已經執行的怎麼辦呢?
所以,一個完整的事務,絕對不是簡單的 sql 集合,還需要滿足如下四個屬性:
事務的提交方式常見的有兩種:
檢視事務提交方式
mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | ON | +---------------+-------+ 1 row in set (0.41 sec)
用 SET 來改變 MySQL 的自動提交模式
mysql> SET AUTOCOMMIT=0; #SET AUTOCOMMIT=0 禁止自動提交 Query OK, 0 rows affected (0.00 sec) mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | OFF | +---------------+-------+ 1 row in set (0.00 sec) mysql> SET AUTOCOMMIT=1; #SET AUTOCOMMIT=1 開啟自動提交 Query OK, 0 rows affected (0.00 sec) mysql> show variables like 'autocommit'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | autocommit | ON | +---------------+-------+ 1 row in set (0.01 sec)
開啟事務:start transaction;
執行多條SQL語句
回滾或提交:rollback/commit;
說明:rollback即是全部失敗,commit即是全部成功
髒讀(第一個事務修改資料但沒有提交,第二個事務就讀取,在第一個事務回滾後,第二個事務讀取的就是髒資料)
不可重複讀(一個事務兩次讀取資料,中間有另一個事務修改,第一個事務兩次讀取的資料就不同)
幻讀 一個事務兩次讀取,中間有另一個事務執行了插入操作,造成第一個事務看到不同的結果
讀未提交(Read Uncommitted): 在該隔離級別,所有的事務都可以看到其他事務沒有提交的執行結果。(實際生產中不可能使用這種隔離級別的),但是相當於沒有任何隔離性,也會有很多並行問題,如髒讀,幻讀,不可重複讀等,我們上面為了做實驗方便,用的就是這個隔離性。
讀提交(Read Committed) :該隔離級別是大多數資料庫的預設的隔離級別(不是 MySQL 預設的)。它滿足了隔離的簡單定義:一個事務只能看到其他的已經提交的事務所做的改變。這種隔離級別會引起不可重複讀,即一個事務執行時,如果多次 select, 可能得到不同的結果。
可重複讀(Repeatable Read): 這是 MySQL 預設的隔離級別,它確保同一個事務,在執行中,多次讀取運算元據時,會看到同樣的資料行。但是會有幻讀問題。
序列化(Serializable): 這是事務的最高隔離級別,它通過強制事務排序,使之不可能相互衝突,從而解決了幻讀的問題。它在每個讀的資料行上面加上共用鎖。但是可能會導致超時和鎖競爭(這種隔離級別太極端,實際生產基本不使用)
隔離級別 | 髒讀 | 不可重複讀 | 幻讀 |
---|---|---|---|
讀未提交 | × | × | × |
讀提交 | √ | × | × |
可重複讀 | √ | √ | × |
序列化 | √ | √ | √ |
到此這篇關於MySQL資料庫事務原理及應用的文章就介紹到這了,更多相關MySQL資料庫事務內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45