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 可以包含可选的 GLOBAL 或 SESSION 关键字来指示语句的范围。要设置事务隔离级别,请使用 ISOLATION LEVEL 层级子句。不允许在同一 SET TRANSACTION 语句中指定多个 ISOLATION LEVEL 子句。默认的隔离级别是 REPEATABLE READ。其他允许的值有 READ COMMITTED、READ UNCOMMITTED 和 SERIALIZABLE。要设置事务访问模式,请使用 READ WRITE 或 READ ONLY 子句。不允许在同一 SET TRANSACTION 语句中指定多个访问模式子句。默认情况下,事务以读/写模式进行,同时允许对事务中使用的表进行读写操作。可以使用指定 READ WRITE 的 SET TRANSACTION 显式指定此访问模式。如果事务访问模式设置为 READ ONLY,则禁止更改表。这可能使存储引擎能够在不允许写入时进行性能改进。在只读模式下,仍然可以使用 DML 语句更改用 TEMPORARY 关键字创建的表。与永久表一样,不允许使用 DDL 语句更改。也可以使用 START TRANSACTION 语句为单个事务指定 READ WRITE 和 READ ONLY 访问模式。可以设置事务特性全局有效,仅限于当前会话,或仅限于下一个事务:■ 在事务中允许该语句,但不影响当前正在进行的事务。■ 如果在事务之间执行,该语句将覆盖前面任何为下一个事务设置的命名特性值的语句。● 没有 SESSION 或 GLOBAL 关键字: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 选项。此选项的级别值使用破折号而不是空格,因此允许的值为 READ-UNCOMMITTED、READ-COMMITTED、REPEATABLE-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_isolation 和 transaction_read_only 系统变量:SET TRANSACTION 允许使用可选的 GLOBAL 和 SESSION 关键字来设置不同作用域级别的事务特性。将值赋给 transaction_isolation 和 transaction_read_only 系统变量的 SET 语句具有设置这些变量在不同范围级别的语法。下表显示了由每个 SET TRANSACTION 和变量赋值语法设置的特性范围级别。用于事务特性的 SET TRANSACTION 语法 | |
| SET GLOBAL TRANSACTION transaction_characteristic | |
| SET SESSION TRANSACTION transaction_characteristic | |
| SET TRANSACTION transaction_characteristic | |
| |
| 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 | |
| |
| |
SELECT @@GLOBAL.transaction_isolation, @@GLOBAL.transaction_read_only;
SELECT @@SESSION.transaction_isolation, @@SESSION.transaction_read_only;
https://dev.mysql.com/doc/refman/8.0/en/set-transaction.html