MySQL 8.x 隔离级别调整

MySQL 8.x 隔离级别调整

    • [1. 如何查看隔离级别?](#1. 如何查看隔离级别?)
    • [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):

  1. 找到 [mysqld] 配置节。

  2. 添加或修改如下行:

    ini 复制代码
    [mysqld]
    transaction-isolation = READ-COMMITTED
  3. 重启 MySQL 服务。


⚠️ 切换到 RC 后的核心变化

从 RR 切换到 RC,数据库行为会发生以下显著变化:

  1. 不再防止不可重复读: 同一个事务内,两次执行同一条 SELECT 可能得到不同结果(如果期间有其他事务提交了修改)。
  2. 性能提升: RC 级别下锁的粒度更小,间隙锁 (Gap Lock) 基本失效,这能减少死锁的概率并提高并发能力。
  3. Binlog 格式要求: 在 RC 级别下,建议将 binlog_format 设置为 ROW(行级格式),否则在主从复制时可能会出现数据不一致。

若有转载,请标明出处:https://blog.csdn.net/CharlesYuangc/article/details/160532549

相关推荐
l1t2 小时前
DeepSeek总结的面向 PostgreSQL 分析和 HTAP 工作负载的两种高性能表访问方法
数据库·postgresql
许愿OvO2 小时前
Redis 7.4.8高可用集群实战:主从复制+哨兵+Cluster全解析
数据库·redis·bootstrap
2401_831419442 小时前
如何用 http 模块创建一个基础的 Web 服务器处理请求
jvm·数据库·python
pele2 小时前
Redis如何防止AOF文件无限增大_触发BGREWRITEAOF命令进行日志重写
jvm·数据库·python
qq_414256572 小时前
golang如何设计HTTP中间件链_golang HTTP中间件链设计方法
jvm·数据库·python
m0_746752302 小时前
如何用方法简写语法在对象字面量中快速定义成员函数
jvm·数据库·python
qq_189807032 小时前
JavaScript 中高效定位二维数组间不匹配元素的行列索引
jvm·数据库·python
qq_349317482 小时前
Python GUI界面如何实现主题美化_引入ttk模块实现原生外观风格
jvm·数据库·python
草履虫君2 小时前
我们用纯命令行方式,给openclaw配置minimax2.7
数据库·经验分享·功能测试·ai