一文帶你理解MySQL?TCL?事務控制
MySQL 中并非所有的數(shù)據(jù)庫存儲引擎都支持事務操作,比如 MyISAM 就不支持。所以,使用事務處理的時候一定要確定所操作的表示是否支持事務處理,可以通過查看建表語句來查看有沒有指定事務類型的存儲引擎。當然,事務處理是為了保障表數(shù)據(jù)原子性、一致性、隔離性、持久性。這些都需要消耗系統(tǒng)資源,請謹慎選擇。
本文以數(shù)據(jù)庫引擎 InnoDB 為例演示命令行模式下事務的基本操作。
1.隔離級別查看與設置
(1)查看全局和當前會話的事務隔離級別。
-- 查看全局 SELECT @@global.transaction_isolation; -- 查看當前會話 SELECT @@transaction_isolation; SELECT @@session.transaction_isolation; SHOW VARIABLES LIKE 'transaction_isolation';
從 MySQL 8.0 起,tx_isolation 變量被 transaction_isolation 變量替換了,所以請使用最新的變量 transaction_isolation。
MySQL InnoDB 缺省隔離級別是可重復讀(Repeatable Read)。
(2)更改事務的隔離級別。
MySQL 提供了 SET TRANSACTION 語句,該語句可以改變單個會話或全局的事務隔離級別。
SET [GLOBAL | SESSION] TRANSACTION transaction_characteristic [, transaction_characteristic] ... transaction_characteristic: { ISOLATION LEVEL level | access_mode } level: { REPEATABLE READ | READ COMMITTED | READ UNCOMMITTED | SERIALIZABLE } access_mode: { READ WRITE | READ ONLY }
不顯示指明 SESSION 或 GLOBAL,默認是 SESSION,即設置當前會話的事務隔離級別。如果使用 GLOBAL 關(guān)鍵字,為之后的所有新連接設置事務隔離級別,需要 SUPER 權(quán)限來做這個。
比如更改事務隔離級別為讀已提交。
-- 更改當前會話事務隔離級別(可省略 SESSION) SET TRANSACTION ISOLATION LEVEL READ COMMITTED; SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED; -- 更改全局事務隔離級別 SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;
也可以直接使用 SET 語句為變更系統(tǒng)變量 transaction_isolation 的值修改當前 session 的事務隔離級別。
SET @@transaction_isolation='READ-COMMITTED';
或者設置全局事務隔離級別為讀已提交。
SET @@global.transaction_isolation='READ-COMMITTED';
2.自動提交事務
2.1 查看是否自動提交事務
MySQL 默認事務操作模式是自動提交模式(autocommit )。
系統(tǒng)變量 @@autocommit 用來控制一條SQL語句提交后是否自動執(zhí)行,默認值是1,表示在命令行模式下每條增刪改語句在鍵入回車后,都會立即生效,而不需要手動 commit。我們可以把它關(guān)閉,關(guān)閉之后需要 commit,SQL 語句才會真正生效。
由于系統(tǒng)變量 autocommit 分為會話系統(tǒng)變量與全局系統(tǒng)變量,所以查詢的時候,最好區(qū)別一下。
查看當前會話是否處于自動提交模式。
SELECT @@autocommit; SELECT @@session.autocommit; SHOW SESSION VARIABLES LIKE 'autocommit';
如果返回結(jié)果為 1 或 ON,則表示當前會話處于自動提交模式;如果返回結(jié)果為 0 或 OFF,則表示當前會話未處于自動提交模式。
如果想查看全局配置,可查看系統(tǒng)變量 @@global.autocommit。
SELECT @@global.autocommit; SHOW GLOBAL VARIABLES LIKE 'autocommit';
2.2 關(guān)閉或開啟自動提交事務
- 關(guān)閉自動提交事務。
MySQL默認自動提交事務,即除非顯式的開啟事務(BEGIN 或 START TRANSACTION),否則每條 SOL 語句都會被當做一個單獨的事務自動執(zhí)行。但有些情況下,我們需要關(guān)閉事務自動提交來保證數(shù)據(jù)的一致性。
關(guān)閉自動提交事務主要有兩種方法。一種是臨時關(guān)閉,只對當前會話有效。第二種是永久關(guān)閉,對所有會話有效。
第一種:臨時關(guān)閉。
關(guān)閉當前會話的自動提交事務。
SET autocommit = 0; SET @@autocommit = 0; SET @@session.autocommit = 0; SET SESSION autocommit = 0;
這樣之后,所有增刪改語句,都必須使用 commit 之后,才能生效。
第二種:永久關(guān)閉。
在 MySQL 中,要永久地關(guān)閉自動提交事務,必須在配置文件中進行設置,以便在每次啟動 MySQL 服務器時都保持這個設置。
找到 MySQL 的配置文件。在大多數(shù)情況下,MySQL 的配置文件名為 my.cnf 或 my.ini,具體位置取決于您的操作系統(tǒng)和安裝方式。
打開配置文件并找到 [mysqld] 部分,添加或修改下面的配置項。
[mysqld] init_connect='SET autocommit=0'
保存,然后重新啟動 MySQL 服務器即可生效。
- 開啟自動提交事務。
如果需要,可以開啟自動提交模式。
SET autocommit = 1; SET @@autocommit = 1; SET @@session.autocommit = 1; SET SESSION autocommit = 1;
要想永久有效,需要將上面配置文件中的配置項init_connect='SET autocommit=0'
刪除或設置為 1。
3.事務執(zhí)行基本流程
首先創(chuàng)建一個測試數(shù)據(jù)表,建表語句如下:
CREATE TABLE transaction_test(id int primary key)engine=InnoDB;
- 開啟一個事務。
BEGIN; # 或 START TRANSACTION;
- 執(zhí)行一系列增刪改語句。
INSERT INTO transaction_test VALUES(1);
- 手動提交或回滾。
事務回滾:
ROLLBACK;
回滾后我們查看數(shù)據(jù)表中的數(shù)據(jù)。
SELECT * FROM transaction_test; Empty set (0.00 sec)
表中沒有數(shù)據(jù),回滾成功。
手動提交事務:
COMMIT;
提交后,再 ROLLBACK 則不能回滾了,數(shù)據(jù)已經(jīng)插入到數(shù)據(jù)表了。這里需要注意的是,在當前會話中,我們還沒有手動 COMMIT 提交事務的時候,表中的數(shù)據(jù)已經(jīng)被插入了,但對于其它會話,如果事務隔離級別是 READ COMMITED,那么在 COMMIT 之前,查詢不到新插入的記錄。
4.設置事務的保存點
在 MySQL 中,您可以使用事務保存點(Savepoint)來標記事務中的一個特定位置,以便在事務進行過程中進行部分回滾。事務保存點可以在事務內(nèi)部創(chuàng)建,并且可以用于回滾到該保存點之前的狀態(tài),而不影響事務中的其他操作。
- 設置折返點
SAVEPOINT identifier;
- 回滾至折返點
ROLLBACK [WORK] TO [SAVEPOINT] identifier;
這將撤銷從保存點創(chuàng)建后到當前位置之間的所有操作。
- 提交或繼續(xù)事務。
如果您滿意回滾后的狀態(tài),可以繼續(xù)進行其他操作,并最終提交事務。
COMMIT; -- 提交事務
通過使用事務保存點,您可以更細粒度地控制事務的回滾操作,以適應復雜的業(yè)務需求。請注意,保存點只在當前事務內(nèi)部有效,并且一旦事務提交或回滾,保存點將被清除。
參考文獻
13.3 Transactional and Locking Statements
MySQL 8.0 Reference Manual :: MySQL Glossary
15.7.2.1 Transaction Isolation Levels - MySQL
13.3.7 SET TRANSACTION Statement
MySQL 8.0 Reference Manual :: 5.1.8 Server System Variables
到此這篇關(guān)于一文帶你理解MySQL TCL 事務控制的文章就介紹到這了,更多相關(guān)MySQL TCL 事務控制內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql正確刪除數(shù)據(jù)的方法(drop,delete,truncate)
這篇文章主要給大家介紹了關(guān)于mysql正確刪除數(shù)據(jù)的相關(guān)資料,DELETE語句是MySQL中最常用的刪除數(shù)據(jù)的方式之一,但也有幾種其他方法來實現(xiàn),需要的朋友可以參考下2023-10-10MySQL數(shù)據(jù)庫21條最佳性能優(yōu)化經(jīng)驗
數(shù)據(jù)庫的操作越來越成為整個應用的性能瓶頸了,這點對于Web應用尤其明顯。這篇文章主要介紹了MySQL數(shù)據(jù)庫21條最佳性能優(yōu)化經(jīng)驗的相關(guān)資料,需要的朋友可以參考下2016-10-10MySQL遞歸sql語句WITH表達式實現(xiàn)方法代碼
SQL遞歸查詢語句是指通過遞歸方式對數(shù)據(jù)進行查詢的語句,下面這篇文章主要給大家介紹了關(guān)于MySQL遞歸sql語句WITH表達式實現(xiàn)的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2024-01-01MySQL用戶權(quán)限設置保護數(shù)據(jù)庫安全
MySQL用戶權(quán)限設置是保護數(shù)據(jù)庫安全的重要措施之一。通過為用戶設置不同的權(quán)限,可以控制用戶對數(shù)據(jù)庫的訪問能力,包括讀取、修改、刪除、創(chuàng)建等操作。合理設置用戶權(quán)限可以避免誤操作、非法訪問等安全問題2023-05-05Mysql從5.6.14安全升級至mysql5.6.25的方法
這篇文章主要介紹了Mysql從5.6.14安全升級至mysql5.6.25的方法,本教程講的非常詳細,具有參考借鑒價值,需要的朋友參考下吧2016-08-08mysql 5.7.16 安裝配置方法圖文教程(ubuntu 16.04)
這篇文章主要為大家分享了ubuntu 16.04下mysql 5.7.16 安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-01-01mariadb集群搭建---Galera Cluster+ProxySQL教程
這篇文章主要介紹了mariadb集群搭建---Galera Cluster+ProxySQL教程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03