婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL查看和修改事務隔離級別的實例講解

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

熱門標簽:博樂電銷機器人 上海市三維地圖標注 南寧外呼系統招商 鄭州網絡外呼系統價錢 怎么更改高德地圖標注 400電話到哪辦理優惠 云南大數據外呼系統 機器人打電銷電話 電話機器人是電腦呼號嗎

查看事務隔離級別

在 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查看和修改事務隔離級別的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • Mysql事務隔離級別之讀提交詳解
  • MySQL四種事務隔離級別詳解
  • MySQL 四種事務隔離級別詳解及對比
  • 深入解析MySQL的事務隔離及其對性能產生的影響
  • MySQL中Innodb的事務隔離級別和鎖的關系的講解教程
  • MySQL數據庫事務隔離級別介紹(Transaction Isolation Level)
  • MySQL InnoDB中的鎖機制深入講解
  • MySQL鎖機制與用法分析
  • 深入理解Mysql事務隔離級別與鎖機制問題

標簽:恩施 益陽 澳門 杭州 秦皇島 定西 寧夏 白銀

巨人網絡通訊聲明:本文標題《MySQL查看和修改事務隔離級別的實例講解》,本文關鍵詞  MySQL,查看,和,修改,事務,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL查看和修改事務隔離級別的實例講解》相關的同類信息!
  • 本頁收集關于MySQL查看和修改事務隔離級別的實例講解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 内丘县| 元谋县| 洛扎县| 女性| 西昌市| 莫力| 顺平县| 中卫市| 崇礼县| 黑水县| 鹿邑县| 齐齐哈尔市| 太保市| 陕西省| 宣城市| 保康县| 班戈县| 日照市| 镇安县| 衡南县| 云安县| 威远县| 鄂州市| 蒙山县| 甘洛县| 辽源市| 连江县| 丹巴县| 高安市| 太仓市| 当雄县| 开化县| 奈曼旗| 泾源县| 阿拉善左旗| 门头沟区| 蒲城县| 阿克陶县| 瑞丽市| 连平县| 黑水县|