色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

MySQL查看和修改事務隔離級別的實例講解

瀏覽:4日期:2023-10-16 10:40:17

查看事務隔離級別

在 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:Usersleovo>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)

示例 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查看和修改事務隔離級別的實例講解的詳細內容,更多關于MySQL查看和修改事務隔離級別的資料請關注好吧啦網其它相關文章!

標簽: MySQL 數據庫
相關文章:
主站蜘蛛池模板: 日本国产最新一区二区三区 | 香蕉521av网站永久地址 | 国产女人成人精品视频 | 日本综合欧美一区二区三区 | 久久在线综合 | 日韩美女啪啪 | 免费看香港一级毛片 | 成人在线综合网 | 92av在线 | 国产成人啪一区二区 | 日韩欧美第一页 | 国产片在线观看狂喷潮bt天堂 | 国产视频综合 | 欧美特黄一区二区三区 | 久久久久久91精品色婷婷 | 亚洲精品久久久成人 | 欧美巨大精品欧美一区二区 | 91精品国产免费久久久久久青草 | 久久影院视频 | 欧美精品在线视频 | 波多野结衣视频在线观看地址免费 | 一品道一本香蕉视频 | 久久爱一区 | 波多野在线播放 | 国产美女一级毛片 | 最新国产三级在线不卡视频 | 日本免费一区二区三区视频 | 成年日韩片av在线网站 | 荡公乱妇蒂芙尼中文字幕 | 精品久久免费视频 | 成年男人午夜片免费观看 | 成人性生免费视频 | 永久黄网站色视频免费网站 | 日韩欧美在线精品 | 欧美一级久久久久久久久大 | 69国产成人综合久久精品91 | 国产精品久久自在自线观看 | 国产自在自线午夜精品视频 | 亚洲精品永久一区 | 久久国产影视免费精品 | 视频在线观看一区 |