文档首页
MySQL 9.0 参考手册
相关文档 下载此手册
PDF (US Ltr) - 40.0Mb
PDF (A4) - 40.1Mb
手册页 (TGZ) - 258.2Kb
手册页 (Zip) - 365.3Kb
Info (Gzip) - 4.0Mb
Info (Zip) - 4.0Mb


MySQL 9.0 参考手册  /  ...  /  SET TRANSACTION 语句

15.3.7 SET TRANSACTION 语句

SET [GLOBAL | SESSION] TRANSACTION
    transaction_characteristic [, transaction_characteristic] ...

transaction_characteristic: {
    ISOLATION LEVEL level
  | access_mode
}

level: {
     REPEATABLE READ
   | READ COMMITTED
   | READ UNCOMMITTED
   | SERIALIZABLE
}

access_mode: {
     READ WRITE
   | READ ONLY
}

此语句指定事务特性。它接受以逗号分隔的一个或多个特性值列表。每个特性值设置事务的隔离级别或访问模式。隔离级别用于对InnoDB表进行操作。访问模式指定事务是在读/写模式下还是只读模式下运行。

此外,SET TRANSACTION 可以包含可选的GLOBALSESSION 关键字,以指示语句的作用域。

事务隔离级别

要设置事务隔离级别,请使用ISOLATION LEVEL level 子句。不允许在同一个SET TRANSACTION 语句中指定多个ISOLATION LEVEL 子句。

默认隔离级别为REPEATABLE READ。其他允许的值为READ COMMITTEDREAD UNCOMMITTED,以及SERIALIZABLE。有关这些隔离级别的信息,请参见第 17.7.2.1 节,“事务隔离级别”

事务访问模式

要设置事务访问模式,请使用READ WRITEREAD ONLY子句。不允许在同一SET TRANSACTION语句中指定多个访问模式子句。

默认情况下,事务在读写模式下进行,允许对事务中使用的表进行读写操作。可以使用带有READ WRITE访问模式的SET TRANSACTION明确指定此模式。

如果将事务访问模式设置为READ ONLY,则禁止对表进行更改。这可能使存储引擎能够在不允许写入时进行性能改进。

在只读模式下,仍然可以使用 DML 语句更改使用TEMPORARY关键字创建的表。与永久表一样,不允许使用 DDL 语句进行更改。

也可以使用START TRANSACTION语句为单个事务指定READ WRITEREAD ONLY访问模式。

事务特征范围

您可以全局设置事务特征,也可以为当前会话或仅为下一个事务设置事务特征。

  • 使用GLOBAL关键字

    • 该语句适用于所有后续会话的全局范围。

    • 现有会话不受影响。

  • 使用SESSION关键字

    • 该语句适用于在当前会话中执行的所有后续事务。

    • 该语句允许在事务中执行,但不影响当前正在进行的事务。

    • 如果在事务之间执行,该语句将覆盖先前设置了命名特征的下一个事务值的任何语句。

  • 不使用任何SESSIONGLOBAL关键字

    • 该语句仅适用于在会话中执行的下一个单个事务。

    • 后续事务将恢复使用会话中命名特征的值。

    • 该语句不允许在事务中执行。

      mysql> START TRANSACTION;
      Query OK, 0 rows affected (0.02 sec)
      
      mysql> SET TRANSACTION ISOLATION LEVEL SERIALIZABLE;
      ERROR 1568 (25001): Transaction characteristics can't be changed
      while a transaction is in progress

更改全局事务特征需要CONNECTION_ADMIN权限(或已弃用的SUPER权限)。任何会话都可以自由更改其会话特征(即使在事务中间),或者更改其下一个事务的特征(在该事务开始之前)。

要在服务器启动时设置全局隔离级别,请在命令行或选项文件中使用--transaction-isolation=level选项。此选项的level值使用连字符而不是空格,因此允许的值为READ-UNCOMMITTEDREAD-COMMITTEDREPEATABLE-READ,或SERIALIZABLE

类似地,要在服务器启动时设置全局事务访问模式,请使用--transaction-read-only选项。默认值为OFF(读写模式),但可以将其设置为ON以设置为只读模式。

例如,要将隔离级别设置为REPEATABLE READ,并将访问模式设置为READ WRITE,请在选项文件的[mysqld]部分中使用以下几行

[mysqld]
transaction-isolation = REPEATABLE-READ
transaction-read-only = OFF

在运行时,可以使用SET TRANSACTION语句(如前所述)间接设置全局、会话和下一个事务范围级别的特征。也可以使用SET语句直接设置这些特征,将值分配给transaction_isolationtransaction_read_only系统变量。

以下表格显示了由每个SET TRANSACTION和变量赋值语法设置的特征范围级别。

表 15.9 SET TRANSACTION 事务特征语法

语法 受影响的特征范围
SET GLOBAL TRANSACTION transaction_characteristic 全局范围
SET SESSION TRANSACTION transaction_characteristic 会话范围
SET TRANSACTION transaction_characteristic 仅下一个事务

表 15.10 SET 事务特征语法

语法 受影响的特征范围
SET GLOBAL var_name = value 全局范围
SET @@GLOBAL.var_name = value 全局范围
SET PERSIST var_name = value 全局范围
SET @@PERSIST.var_name = value 全局范围
SET PERSIST_ONLY var_name = value 无运行时效果
SET @@PERSIST_ONLY.var_name = value 无运行时效果
SET SESSION var_name = value 会话范围
SET @@SESSION.var_name = value 会话范围
SET var_name = value 会话范围
SET @@var_name = value 仅下一个事务

可以检查运行时事务特征的全局值和会话值。

SELECT @@GLOBAL.transaction_isolation, @@GLOBAL.transaction_read_only;
SELECT @@SESSION.transaction_isolation, @@SESSION.transaction_read_only;