MySQL檢視和修改事務隔離級別的例項講解
檢視事務隔離級別
在 MySQL 中,可以通過show variables like '%tx_isolation%'或select @@tx_isolation;語句來檢視當前事務隔離級別。
檢視當前事務隔離級別的 SQL 語句和執行結果如下:
mysql> show variables like '%tx_isolation%'; +---------------+-----------------+ | Variable_name | Value | +---------------+-----------------+ | tx_isolation | REPEATABLE-READ | +---------------+-----------------+ 1 row in set,1 warning (0.17 sec) mysql> select @@tx_isolation; +-----------------+ | @@tx_isolation | +-----------------+ | REPEATABLE-READ | +-----------------+ 1 row in set,1 warning (0.00 sec)
結果顯示,目前 MySQL 的事務隔離級別是 REPEATABLE-READ。
另外,還可以使用下列語句分別查詢全域性和會話的事務隔離級別:
SELECT @@global.tx_isolation; SELECT @@session.tx_isolation;
提示:在MySQL 8.0.3 中,tx_isolation 變數被 transaction_isolation 變數替換了。在 MySQL 8.0.3 版本中查詢事務隔離級別,只要把上述查詢語句中的 tx_isolation 變數替換成 transaction_isolation 變數即可。
修改事務隔離級別
MySQL 提供了 SET TRANSACTION 語句,該語句可以改變單個會話或全域性的事務隔離級別。語法格式如下:
SET [SESSION | GLOBAL] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE}
其中,SESSION 和 GLOBAL 關鍵字用來指定修改的事務隔離級別的範圍:
- SESSION:表示修改的事務隔離級別將應用於當前 session(當前 cmd 視窗)內的所有事務;
- GLOBAL:表示修改的事務隔離級別將應用於所有 session(全域性)中的所有事務,且當前已經存在的 session 不受影響;
- 如果省略 SESSION 和 GLOBAL,表示修改的事務隔離級別將應用於當前 session 內的下一個還未開始的事務。
任何使用者都能改變會話的事務隔離級別,但是隻有擁有 SUPER 許可權的使用者才能改變全域性的事務隔離級別。
如果使用普通使用者修改全域性事務隔離級別,就會提示需要超級許可權才能執行此操作的錯誤資訊,SQL 語句和執行結果如下:
C:\Users\leovo>mysql -utestuser -p Enter password: ****** Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 41 Server version: 5.7.29-log MySQL Community Server (GPL) Copyright (c) 2000,2020,Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> SET GLOBAL TRANSACTION ISOLATION LEVEL READ UNCOMMITTED; ERROR 1227 (42000): Access denied; you need (at least one of) the SUPER privilege(s) for this operation mysql> SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED; Query OK,0 rows affected (0.00 sec)
示例 1
使用 SET TRANSACTION 語句分別修改 session 和全域性的事務隔離級別SQL 語句和執行結果如下:
mysql> select @@session.tx_isolation; +------------------------+ | @@session.tx_isolation | +------------------------+ | SERIALIZABLE | +------------------------+ 1 row in set,1 warning (0.00 sec) mysql> SET GLOBAL TRANSACTION ISOLATION LEVEL REPEATABLE READ; Query OK,0 rows affected (0.00 sec) mysql> select @@global.tx_isolation; +-----------------------+ | @@global.tx_isolation | +-----------------------+ | REPEATABLE-READ | +-----------------------+ 1 row in set,1 warning (0.00 sec)
還可以使用 set tx_isolation 命令直接修改當前 session 的事務隔離級別,SQL 語句和執行結果如下:
mysql> set tx_isolation='READ-COMMITTED'; Query OK,0 rows affected,1 warning (0.00 sec) mysql> select @@session.tx_isolation; +------------------------+ | @@session.tx_isolation | +------------------------+ | READ-COMMITTED | +------------------------+ 1 row in set,1 warning (0.00 sec)
知識點補充
Mysql事務隔離級別之讀提交流程圖
以上就是MySQL檢視和修改事務隔離級別的例項講解的詳細內容,更多關於MySQL檢視和修改事務隔離級別的資料請關注我們其它相關文章!