0

0

mysql默认事务隔离级别是什么_mysql配置说明

P粉602998670

P粉602998670

发布时间:2026-01-10 00:53:17

|

928人浏览过

|

来源于php中文网

原创

MySQL默认事务隔离级别是REPEATABLE READ,由InnoDB强制实现;查级别需按版本选变量(5.7+用transaction_isolation,5.6-用tx_isolation);改级别分SESSION、GLOBAL、配置文件三类作用域;大厂常切READ COMMITTED以降锁、减阻塞、合直觉,但须验证业务兼容性。

mysql默认事务隔离级别是什么_mysql配置说明

MySQL 默认事务隔离级别是 REPEATABLE READ(可重复读),由 InnoDB 存储引擎强制实现,且自 MySQL 5.1 起成为全局默认值。这不是配置出来的“习惯”,而是底层 MVCC + 间隙锁协同保障主从一致性的硬性设计结果。

怎么查当前隔离级别?别用错变量名

不同 MySQL 版本使用不同系统变量,混用会导致查不到或报错:

  • MySQL 5.7 及之后(含 8.0):用 @@transaction_isolation@@GLOBAL.transaction_isolation
  • MySQL 5.6 及更早:用 @@tx_isolation@@GLOBAL.tx_isolation
SELECT @@SESSION.transaction_isolation, @@GLOBAL.transaction_isolation;

如果返回类似 'REPEATABLE-READ'(注意是短横线而非下划线),说明生效;若返回空或报错 Unknown system variable,大概率版本不匹配,立刻切回 tx_isolation 查。

怎么改?session、global、配置文件三者效果完全不同

改隔离级别不是“设一次就永远生效”,必须分清作用域

  • SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;:只影响当前连接后续事务,断连即失效
  • SET GLOBAL TRANSACTION ISOLATION LEVEL READ COMMITTED;:影响所有新建连接(已有连接不变),需 SUPER 权限,重启后丢失
  • /etc/my.cnf 中写 transaction-isolation = READ-COMMITTED:服务重启后对所有连接生效,但无法热加载

⚠️ 注意:GLOBAL 设置不会改变当前已存在的会话,线上调参前务必确认连接池是否复用旧连接——很多 Java 应用用 Druid/Hikari 连接池,改了 global 后新连接才走新级别,老连接仍卡在 REPEATABLE READ

Runwayml(AI painting)
Runwayml(AI painting)

Runway 平台的文本生成图像AI工具

下载

为什么大厂线上常改成 READ COMMITTED?不是默认就好吗

MySQL 默认选 REPEATABLE READ 是历史包袱:早期 binlog 格式只有 STATEMENT,配合 RC 会导致主从不一致(删/插顺序被重排)。但现在普遍用 ROW 格式 binlog,这个限制已解除。

改用 READ COMMITTED 的真实动因是:

  • 降低锁粒度:RC 不用间隙锁(Gap Lock),高并发 INSERT 场景下死锁概率显著下降
  • 减少长事务阻塞:RR 下一个长事务会 hold 住 MVCC 快照,导致 purge 线程无法清理旧版本,undo 表空间暴涨
  • 语义更贴近直觉:开发者通常预期“只能读到已提交数据”,而不是“同一事务内反复读都一样”

但切换前必须验证:业务 SQL 是否依赖 RR 的可重复性?比如报表类任务在事务中多次 SELECT COUNT(*),换 RC 后可能因中间有其他事务提交而结果漂移。

真正容易被忽略的点是:隔离级别不是孤立参数,它和 binlog_formatinnodb_lock_wait_timeout、甚至应用层重试逻辑强耦合。调之前先看慢日志里有没有大量 Lock wait timeout exceeded,再决定是调级别,还是优化 SQL 加索引,或者干脆加 SELECT ... FOR UPDATE 显式控制。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

829

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

735

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

733

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

396

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

c++主流开发框架汇总
c++主流开发框架汇总

本专题整合了c++开发框架推荐,阅读专题下面的文章了解更多详细内容。

3

2026.01.09

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号