濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > MySQL查看和修改事務(wù)隔離級(jí)別的實(shí)例講解

MySQL查看和修改事務(wù)隔離級(jí)別的實(shí)例講解

熱門(mén)標(biāo)簽:博樂(lè)電銷(xiāo)機(jī)器人 上海市三維地圖標(biāo)注 南寧外呼系統(tǒng)招商 鄭州網(wǎng)絡(luò)外呼系統(tǒng)價(jià)錢(qián) 怎么更改高德地圖標(biāo)注 400電話到哪辦理優(yōu)惠 云南大數(shù)據(jù)外呼系統(tǒng) 機(jī)器人打電銷(xiāo)電話 電話機(jī)器人是電腦呼號(hào)嗎

查看事務(wù)隔離級(jí)別

在 MySQL 中,可以通過(guò)show variables like '%tx_isolation%'或select @@tx_isolation;語(yǔ)句來(lái)查看當(dāng)前事務(wù)隔離級(jí)別。

查看當(dāng)前事務(wù)隔離級(jí)別的 SQL 語(yǔ)句和運(yùn)行結(jié)果如下:

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)

結(jié)果顯示,目前 MySQL 的事務(wù)隔離級(jí)別是 REPEATABLE-READ。

另外,還可以使用下列語(yǔ)句分別查詢?nèi)趾蜁?huì)話的事務(wù)隔離級(jí)別:

SELECT @@global.tx_isolation;
SELECT @@session.tx_isolation;

提示:在MySQL 8.0.3 中,tx_isolation 變量被 transaction_isolation 變量替換了。在 MySQL 8.0.3 版本中查詢事務(wù)隔離級(jí)別,只要把上述查詢語(yǔ)句中的 tx_isolation 變量替換成 transaction_isolation 變量即可。

修改事務(wù)隔離級(jí)別

MySQL 提供了 SET TRANSACTION 語(yǔ)句,該語(yǔ)句可以改變單個(gè)會(huì)話或全局的事務(wù)隔離級(jí)別。語(yǔ)法格式如下:

SET [SESSION | GLOBAL] TRANSACTION ISOLATION LEVEL {READ UNCOMMITTED | READ COMMITTED | REPEATABLE READ | SERIALIZABLE}

其中,SESSION 和 GLOBAL 關(guān)鍵字用來(lái)指定修改的事務(wù)隔離級(jí)別的范圍:

  • SESSION:表示修改的事務(wù)隔離級(jí)別將應(yīng)用于當(dāng)前 session(當(dāng)前 cmd 窗口)內(nèi)的所有事務(wù);
  • GLOBAL:表示修改的事務(wù)隔離級(jí)別將應(yīng)用于所有 session(全局)中的所有事務(wù),且當(dāng)前已經(jīng)存在的 session 不受影響;
  • 如果省略 SESSION 和 GLOBAL,表示修改的事務(wù)隔離級(jí)別將應(yīng)用于當(dāng)前 session 內(nèi)的下一個(gè)還未開(kāi)始的事務(wù)。

任何用戶都能改變會(huì)話的事務(wù)隔離級(jí)別,但是只有擁有 SUPER 權(quán)限的用戶才能改變?nèi)值氖聞?wù)隔離級(jí)別。

如果使用普通用戶修改全局事務(wù)隔離級(jí)別,就會(huì)提示需要超級(jí)權(quán)限才能執(zhí)行此操作的錯(cuò)誤信息,SQL 語(yǔ)句和運(yùn)行結(jié)果如下:

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 語(yǔ)句分別修改 session 和全局的事務(wù)隔離級(jí)別SQL 語(yǔ)句和運(yùn)行結(jié)果如下:

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 命令直接修改當(dāng)前 session 的事務(wù)隔離級(jí)別,SQL 語(yǔ)句和運(yùn)行結(jié)果如下:

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)

知識(shí)點(diǎn)補(bǔ)充

Mysql事務(wù)隔離級(jí)別之讀提交流程圖

以上就是MySQL查看和修改事務(wù)隔離級(jí)別的實(shí)例講解的詳細(xì)內(nèi)容,更多關(guān)于MySQL查看和修改事務(wù)隔離級(jí)別的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

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

標(biāo)簽:恩施 益陽(yáng) 澳門(mén) 杭州 秦皇島 定西 寧夏 白銀

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MySQL查看和修改事務(wù)隔離級(jí)別的實(shí)例講解》,本文關(guān)鍵詞  MySQL,查看,和,修改,事務(wù),;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MySQL查看和修改事務(wù)隔離級(jí)別的實(shí)例講解》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于MySQL查看和修改事務(wù)隔離級(jí)別的實(shí)例講解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    中方县| 宁阳县| 新民市| 策勒县| 阿瓦提县| 天祝| 宣恩县| 嫩江县| 禹州市| 桐乡市| 台北市| 蓝山县| 遵化市| 平江县| 吴忠市| 怀仁县| 昭平县| 明光市| 攀枝花市| 泽州县| 余干县| 浦北县| 新田县| 郴州市| 驻马店市| 定西市| 雷山县| 石门县| 金溪县| 普宁市| 东平县| 兴安盟| 临夏县| 剑河县| 汝城县| 财经| 三台县| 云和县| 富平县| 应用必备| 滨海县|