MySQL事务机制和隔离级别使用方式

 更新时间:2025年09月23日 08:48:34   作者:我需要打球  
MySQL事务通过ACID特性保障数据一致性,隔离级别(读未提交、读已提交、可重复读、串行化)平衡并发性能与数据安全,InnoDB默认使用可重复读,依赖MVCC避免脏读和不可重复读,间隙锁减少幻读,需根据场景权衡一致性与性能

MySQL 的事务机制是保证数据库操作一致性和可靠性的核心特性,而隔离级别则用于平衡事务并发时的性能数据一致性

以下是详细解析:

一、事务的四大特性(ACID)

事务(Transaction)是一组不可分割的 SQL 操作,要么全部成功,要么全部失败,核心依赖四大特性:

原子性(Atomicity)

  • 事务中的操作要么全部执行,要么全部回滚(如转账时,扣款和收款必须同时成功或失败)。
  • 实现依赖:Undo Log(记录操作前的状态,用于回滚)。

一致性(Consistency)

  • 事务执行前后,数据从一个合法状态转换到另一个合法状态(如转账后总金额不变)。
  • 由原子性、隔离性、持久性共同保证,部分依赖业务逻辑。

隔离性(Isolation)

  • 多个事务并发执行时,彼此的操作互不干扰(如避免同时修改同一行数据导致的混乱)。
  • 实现依赖:锁机制(行锁、表锁)和 MVCC(多版本并发控制)。

持久性(Durability)

  • 事务提交后,修改永久保存(即使数据库崩溃也不丢失)。
  • 实现依赖:Redo Log(记录操作后的状态,用于崩溃恢复)。

二、事务的隔离级别(SQL 标准定义)

MySQL 的隔离级别从低到高分为 4 种,级别越高,并发控制越严格,但性能开销越大

隔离级别脏读(Dirty Read)不可重复读(Non-repeatable Read)幻读(Phantom Read)说明
读未提交(Read Uncommitted)可能发生可能发生可能发生一个事务可读取另一个未提交的修改,极少使用(如实时数据监控场景)。
读已提交(Read Committed)不会发生可能发生可能发生一个事务只能读取另一个已提交的修改(Oracle 默认级别)。
可重复读(Repeatable Read)不会发生不会发生几乎不发生事务中多次读取同一数据结果一致(MySQL InnoDB 默认级别)。
串行化(Serializable)不会发生不会发生不会发生事务串行执行,完全避免并发问题,但性能极低(仅用于严格数据一致性场景)。

三、各隔离级别的典型场景与实现

1. 读未提交(Read Uncommitted)

  • 场景:几乎不使用,仅适用于允许临时脏数据的极端场景(如实时统计)。
  • 问题:事务 A 修改数据未提交,事务 B 读取到该 “脏数据”,若 A 回滚,B 读取的是无效数据。

2. 读已提交(Read Committed)

  • 场景:大多数互联网应用(如电商订单查询,允许读取最新已提交数据)。
  • 解决脏读:通过行锁保证,事务 A 修改数据时加锁,事务 B 只能读取 A 提交后的数据。
  • 问题:不可重复读 —— 事务 B 两次读取同一行,期间事务 A 修改并提交,导致 B 两次结果不同。

3. 可重复读(Repeatable Read,MySQL 默认)

  • 场景:金融、支付等需保证多次读取一致性的场景(如对账时多次查询同一订单金额)。
  • 解决不可重复读:通过 MVCC 实现,事务启动时生成数据快照,后续读取基于快照,不受其他事务提交影响。
  • 对幻读的优化:InnoDB 通过 “间隙锁(Gap Lock)”+“临键锁(Next-Key Lock)”,几乎避免幻读(特殊场景仍可能发生,但实际使用中可忽略)。

4. 串行化(Serializable)

  • 场景:数据一致性要求极高的场景(如银行核心交易)。
  • 实现:强制事务按顺序执行(加表级锁),完全禁止并发,性能极低。

四、MySQL 中设置与查看隔离级别

1. 查看当前隔离级别

-- MySQL 8.0+
SELECT @@transaction_isolation;

-- MySQL 5.7及以下
SELECT @@tx_isolation;

2. 设置隔离级别(当前会话或全局)

-- 设置当前会话隔离级别
SET SESSION TRANSACTION ISOLATION LEVEL 隔离级别名称;

-- 设置全局隔离级别(需重新连接生效)
SET GLOBAL TRANSACTION ISOLATION LEVEL 隔离级别名称;

-- 示例:设置当前会话为读已提交
SET SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED;

五、事务控制语句

  • 开启事务START TRANSACTION; 或 BEGIN;
  • 提交事务COMMIT;(使修改永久生效)
  • 回滚事务ROLLBACK;(放弃所有修改,恢复到事务开始前状态)
  • 保存点SAVEPOINT 保存点名称;(事务中设置中间点,可回滚到指定点)
START TRANSACTION;
UPDATE account SET balance = balance - 100 WHERE id = 1;
SAVEPOINT sp1;  -- 设置保存点
UPDATE account SET balance = balance + 100 WHERE id = 2;
ROLLBACK TO sp1;  -- 回滚到保存点(仅撤销第二条更新)
COMMIT;

六、面试核心考点

  1. 默认隔离级别:MySQL InnoDB 默认是可重复读(Repeatable Read),这是与其他数据库(如 Oracle 默认读已提交)的重要区别。
  2. MVCC 与隔离级别的关系:MVCC 是实现可重复读和读已提交的核心机制,通过数据多版本快照避免加锁阻塞。
  3. 隔离级别与性能权衡:级别越高,一致性越好,但并发性能越差,实际应用中通常选择读已提交可重复读
  4. 幻读的处理:InnoDB 在可重复读级别通过间隙锁减少幻读,而串行化级别完全避免幻读。

理解事务机制和隔离级别,是设计高并发、高可靠数据库应用的基础,尤其在金融、电商等对数据一致性要求严格的场景中至关重要。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • MySQL中慢SQL优化的不同方式介绍

    MySQL中慢SQL优化的不同方式介绍

    慢 SQL 的优化,主要从两个方面考虑,SQL 语句本身的优化,以及数据库设计的优化,下面小编就来给大家介绍一下有哪些方式可以优化慢 SQL吧
    2025-03-03
  • 详解MySQL中的死锁情况以及对死锁的处理方法

    详解MySQL中的死锁情况以及对死锁的处理方法

    这篇文章主要介绍了详解MySQL中的死锁情况以及对死锁的处理方法,文中主要讨论InnoDB存储引擎中的死锁情况,需要的朋友可以参考下
    2016-01-01
  • MySQL数据库基础篇之入门基础命令小结

    MySQL数据库基础篇之入门基础命令小结

    这篇文章主要介绍了MySQL数据库入门基础命令,总结分析了mysql数据库基本创建、删除、查看、权限等相关操作技巧与注意事项,需要的朋友可以参考下
    2020-05-05
  • MySQL数据库事务隔离级别详解

    MySQL数据库事务隔离级别详解

    这篇文章主要介绍了MySQL数据库事务隔离级别详解的相关资料,需要的朋友可以参考下
    2017-03-03
  • MySQL中DELETE、DROP和TRUNCATE的区别与底层原理分析

    MySQL中DELETE、DROP和TRUNCATE的区别与底层原理分析

    MySQL中DELETE、DROP和TRUNCATE的区别:DELETE删除数据行并保留表结构,支持条件和事务;TRUNCATE清空表数据,不支持条件但速度快;DROP彻底删除表及结构,执行速度为DROP>TRUNCATE>DELETE,存储引擎影响空间释放和自增计数器重置
    2025-07-07
  • MySQL数据库自增主键的间隔不为1的解决方式

    MySQL数据库自增主键的间隔不为1的解决方式

    这篇文章主要介绍了MySQL数据库自增主键的间隔不为1的解决方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • Mysql日志文件和日志类型介绍

    Mysql日志文件和日志类型介绍

    这篇文章主要介绍了Mysql日志文件和日志类型介绍,本文讲解了日志文件类型、错误日志、通用查询日志、慢速查询日志、二进制日志等内容,需要的朋友可以参考下
    2014-12-12
  • mysql 索引的基础操作汇总(四)

    mysql 索引的基础操作汇总(四)

    这篇文章主要为大家详细介绍了mysql 索引的基础操作汇总,涵盖了创建和查看索引、删除索引等操作,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • 详解MySQL中的pid与socket

    详解MySQL中的pid与socket

    不知道你有没有注意过,MySQL 启动时需要配置 pid 及 socket 文件路径。偶尔还会出现因 pid 文件找不到而启动失败的现象,那么 pid 与 socket 文件究竟是干什么用的呢?我们一起来看下本篇文章。
    2021-06-06
  • mysql tmp_table_size和max_heap_table_size大小配置

    mysql tmp_table_size和max_heap_table_size大小配置

    这篇文章主要介绍了mysql tmp_table_size和max_heap_table_size大小配置,需要的朋友可以参考下
    2016-05-05

最新评论