0

0

mysql事务有哪些特性_mysql ACID原理说明

P粉602998670

P粉602998670

发布时间:2026-01-10 09:33:31

|

798人浏览过

|

来源于php中文网

原创

ACID是InnoDB用undo log、redo log、锁机制和doublewrite buffer等组件实现的:原子性靠undo log回滚链,隔离性由MVCC加行锁保障,持久性依赖redo log两阶段提交,一致性是其他三者与约束共同作用的结果。

mysql事务有哪些特性_mysql acid原理说明

MySQL 事务的特性就是 ACID —— 它不是抽象概念,而是 InnoDB 存储引擎用 undo logredo log锁机制doublewrite buffer 等实实在在的组件硬扛出来的。你写的每一条 START TRANSACTION,背后都在触发这些机制协同工作。

原子性靠 undo log 回滚链实现

事务中任意一步失败(比如 UPDATE 违反唯一约束),InnoDB 不会只“撤掉这一步”,而是根据该事务的 undo log 记录,把所有已做的变更逆向还原——就像倒带一样回到事务开始前的状态。

  • undo log 是在事务执行过程中实时写入的,即使事务中途崩溃,重启后也能靠它回滚
  • 大事务(比如批量更新百万行)会产生大量 undo log,可能占满 undo tablespace,导致 ERROR 1205 (HY000): Deadlock found when trying to get lockLock wait timeout exceeded
  • ROLLBACK 不是“删除日志”,而是用日志重放反向操作;所以回滚大事务可能比提交还慢,且引发高 I/O

隔离性由 MVCC + 行锁共同控制

InnoDB 默认隔离级别是 REPEATABLE READ,它不靠锁住整张表来实现,而是结合多版本并发控制(MVCC)和 next-key lock 来平衡安全与性能。

  • 同一事务内多次 SELECT 能看到相同快照,靠的是事务启动时分配的 read view,而不是加读锁
  • UPDATE/DELETE 仍会加行锁或间隙锁,避免幻读;如果只靠 MVCC,INSERT 就可能绕过检查造成数据不一致
  • 切忌在事务里混用 SELECT ... FOR UPDATE 和普通 SELECT:前者会升级为当前读,破坏一致性快照,容易引发死锁

持久性依赖 redo log 的两阶段提交

你执行 COMMIT 后立刻能查到新数据,并不意味着数据已刷进表空间文件——真正落盘靠的是 redo logprepare → commit 两阶段写入。

Sider
Sider

多功能AI浏览器助手,帮助用户进行聊天、写作、阅读、翻译等

下载
  • 只要 redo logcommit 记录写成功(默认 innodb_flush_log_at_trx_commit = 1),即使 MySQL 崩溃,重启时也能从日志恢复已提交事务
  • 设成 02 会提升写入性能,但崩溃可能丢失最多 1 秒事务——线上交易系统严禁这么配
  • redo log 空间有限(默认 48MB),写满会阻塞事务,监控 Innodb_os_log_pending_fsyncsInnodb_log_waits 很关键

一致性是 ACID 的结果,不是独立机制

Consistency 不像其他三项有专属日志或锁结构,它是原子性、隔离性、持久性 + 业务逻辑 + 数据库约束(主键、外键、CHECK)共同达成的效果。

  • 转账例子中“总额不变”不是数据库自动保证的,而是靠你在事务里写对了两条 UPDATE,再配合原子性和隔离性不被干扰
  • InnoDB 会强制校验外键、唯一索引等约束,一旦违反就直接报错并触发回滚——这是它保障一致性最实在的动作
  • 如果你在事务里绕过约束(比如用 INSERT IGNORE 忽略重复键),或在应用层做计算(如余额 = SUM(transactions)),那数据库就管不了“逻辑一致性”了
真正难的从来不是记住 ACID 四个字母,而是理解:每个 COMMIT 都在调用磁盘、内存、锁管理器三套系统协同工作;而任何一个环节配置不当(比如关了 sync_binlog 又没开半同步复制),都可能让“已提交”的事务在主从切换后人间蒸发。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

658

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

244

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

281

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

514

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

253

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

386

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

528

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

597

2023.08.14

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

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

25

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号