查看事務隔離級別
在 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 窗口)內的所有事務;任何用戶都能改變會話的事務隔離級別,但是只有擁有 SUPER 權限的用戶才能改變全局的事務隔離級別。
如果使用普通用戶修改全局事務隔離級別,就會提示需要超級權限才能執行此操作的錯誤信息,SQL 語句和運行結果如下:
C:/Users/leovo>mysql -utestuser -pEnter password: ******Welcome to the MySQL monitor. Commands end with ; or /g.Your MySQL connection id is 41Server 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 itsaffiliates. Other names may be trademarks of their respectiveowners. 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 operationmysql> SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;Query OK, 0 rows affected (0.00 sec)
新聞熱點
疑難解答