MySQL 8.x 隔离级别调整
-
- [1. 如何查看隔离级别?](#1. 如何查看隔离级别?)
-
- 方式一:使用全局函数(推荐,兼容各版本)
- [方式二:使用 `SHOW VARIABLES`](#方式二:使用
SHOW VARIABLES)
- [2. MySQL 默认隔离级别是什么?](#2. MySQL 默认隔离级别是什么?)
- [3. 如何修改隔离级别为 RC (Read Committed)?](#3. 如何修改隔离级别为 RC (Read Committed)?)
-
- [方案 A:仅修改当前会话(立即生效,断开重连后恢复默认)](#方案 A:仅修改当前会话(立即生效,断开重连后恢复默认))
- [方案 B:全局修改(对后续新连接生效,重启 MySQL 后失效)](#方案 B:全局修改(对后续新连接生效,重启 MySQL 后失效))
- [方案 C:永久修改(修改配置文件,重启生效)](#方案 C:永久修改(修改配置文件,重启生效))
- [⚠️ 切换到 RC 后的核心变化](#⚠️ 切换到 RC 后的核心变化)
在 MySQL 中,事务隔离级别决定了多个事务并发执行时相互影响的程度。更多详情可参考《MySQL 数据库 隔离级别 详解》。
- 事务隔离级别决定了在并发访问下,一个事务可以看到其他事务的哪些数据变化。MySQL 支持标准 SQL 的四种隔离级别:
| 隔离级别 | 描述 | 可能发生的问题 |
|---|---|---|
| READ UNCOMMITTED(读未提交) | 可以读取其他事务未提交的数据 | 脏读 |
| READ COMMITTED(读已提交) | 只能读取其他事务已提交的数据 | 不可重复读 |
| REPEATABLE READ(可重复读) | 事务内多次读取同一数据结果相同 | 幻读(InnoDB 会用 Next-Key Lock 避免幻读) |
| SERIALIZABLE(可串行化) | 最严格,事务串行执行 | 性能开销大 |
1. 如何查看隔离级别?
由于 MySQL 不同版本的变量名略有差异(5.7 之前使用 tx_isolation,8.0 之后使用 transaction_isolation),建议使用通用查询方式:
方式一:使用全局函数(推荐,兼容各版本)
sql
-- 查看当前会话的隔离级别
SELECT @@transaction_isolation;
-- 查看全局系统的隔离级别
SELECT @@global.transaction_isolation;
方式二:使用 SHOW VARIABLES
sql
-- 模糊匹配查询
SHOW VARIABLES LIKE 'transaction_isolation';
-- 或者旧版本(5.7以下)使用
SHOW VARIABLES LIKE 'tx_isolation';
2. MySQL 默认隔离级别是什么?
MySQL 的默认隔离级别是:可重复读 (Repeatable Read, RR)。
- 特点: 在同一个事务内,多次读取同一补偿数据的结果是一致的。
- 与其他数据库的区别: 像 Oracle 和 SQL Server 的默认隔离级别通常是 读已提交 (Read Committed, RC)。
- 额外增强: MySQL 的 RR 级别通过 Next-Key Locks(间隙锁+行锁) 在很大程度上解决了"幻读"问题。
3. 如何修改隔离级别为 RC (Read Committed)?
可以根据影响范围,选择以下三种修改方式之一:
方案 A:仅修改当前会话(立即生效,断开重连后恢复默认)
如果只想让当前的连接窗口变成 RC 级别,执行:
sql
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;
方案 B:全局修改(对后续新连接生效,重启 MySQL 后失效)
如果希望整个数据库实例都切换到 RC,但不想重启服务:
sql
SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;
注意:已连接的会话不会改变,只有新创建的连接才会生效。
方案 C:永久修改(修改配置文件,重启生效)
如果希望永久生效,需要修改 MySQL 的配置文件(Linux 下通常是 my.cnf,Windows 下是 my.ini):
-
找到
[mysqld]配置节。 -
添加或修改如下行:
ini[mysqld] transaction-isolation = READ-COMMITTED -
重启 MySQL 服务。
⚠️ 切换到 RC 后的核心变化
从 RR 切换到 RC,数据库行为会发生以下显著变化:
- 不再防止不可重复读: 同一个事务内,两次执行同一条
SELECT可能得到不同结果(如果期间有其他事务提交了修改)。 - 性能提升: RC 级别下锁的粒度更小,间隙锁 (Gap Lock) 基本失效,这能减少死锁的概率并提高并发能力。
- Binlog 格式要求: 在 RC 级别下,建议将
binlog_format设置为 ROW(行级格式),否则在主从复制时可能会出现数据不一致。
若有转载,请标明出处:https://blog.csdn.net/CharlesYuangc/article/details/160532549