0

0

mysql数据库中事务的ACID特性解释

P粉602998670

P粉602998670

发布时间:2026-02-01 10:38:02

|

824人浏览过

|

来源于php中文网

原创

事务的原子性由InnoDB通过Undo Log和Redo Log协同保证;DDL语句会隐式提交,导致ROLLBACK无效;大事务易撑爆undo log;一致性依赖业务逻辑与约束,隔离性需结合锁机制,持久性取决于innodb_flush_log_at_trx_commit配置。

mysql数据库中事务的acid特性解释

事务的原子性靠什么保证?

原子性不是靠 SQL 语句写得“看起来一起执行”就成立的,而是由 InnoDB 存储引擎通过 Undo LogRedo Log 协同实现的。你写 BEGINCOMMITROLLBACK,只是告诉引擎“我要开始/结束一个事务”,真正回滚时,InnoDB 会按 Undo Log 中记录的反向操作(比如 INSERT 对应 DELETEUPDATE 对应反向 UPDATE)逐条还原数据。

  • 如果你在事务中执行了 DROP TABLEALTER TABLE,会**立即触发隐式提交**,后续 ROLLBACK 无效——DDL 是事务“终结者”
  • innodb_flush_log_at_trx_commit 设为 02 虽能提升写性能,但机器断电时可能丢事务;生产环境建议保持默认 1
  • 大事务(如批量更新百万行)容易撑爆 undo log 空间,导致 rollback 极慢甚至卡死,应拆分执行

一致性不是数据库自动兜底的

很多人误以为“用了事务,数据就天然一致”。其实 Consistency 是 ACID 中最依赖业务逻辑的一环:数据库只保证约束(如主键、外键、CHECK)、不破坏已定义的规则;但业务层面的“钱总额不变”“库存不能为负”这类逻辑,必须靠你写对 SQL 顺序、加锁、校验条件来保障。

  • 转账场景下,仅靠 UPDATE account SET balance = balance - 100 WHERE id = 1 + UPDATE account SET balance = balance + 100 WHERE id = 2 不够——若第一条成功、第二条失败且没 ROLLBACK,钱就凭空消失了
  • 没有外键或 ENUM 约束时,status 字段被误设为 'pending_pay'(而合法值只有 'paid'/'canceled'),事务照样提交成功,但业务已不一致
  • SELECT ... FOR UPDATE 在读取余额后加行锁,能防止并发扣款超支,这是手动保一致的关键动作

隔离性失效的典型现场

默认的 REPEATABLE READ 隔离级别看似安全,但在高并发下仍可能遇到幻读(新插入行被读到),而 READ COMMITTED 虽避免幻读,却带来不可重复读问题。是否出问题,取决于你有没有在事务内做“范围条件读 + 后续写入”这类操作。

51shop 网上商城系统
51shop 网上商城系统

51shop 由 PHP 语言开发, 使用快速的 MySQL 数据库保存数据 ,为中小型网站实现网上电子商务提供一个完美的解决方案.一、用户模块1. 用户注册:用户信息包括:用户ID、用户名、用户密码、性别、邮箱、省份、城市、 联系电话等信息,用户注册后不能立即使用,需由管理员激活账号,才可使用(此功能管理员可设置)2. 登录功能3. 资料修改:用户可修改除账号以后的所有资料4. 忘记密码:要求用

下载
  • 执行 SELECT * FROM order WHERE status = 'unpaid' 得到 5 条,接着想把这 5 条全更新为 'processing',但如果别人在你查询后插入了第 6 条未支付订单,REPEATABLE READ 下你查不到它,但更新语句会命中它(InnoDB 的 next-key lock 机制决定),结果更新了 6 条——这就是“幻读”的实际影响
  • SELECT ... LOCK IN SHARE MODEFOR UPDATE 显式加锁,比单纯依赖隔离级别更可控
  • 应用层缓存(如 Redis)和数据库事务不同步时,即使数据库强一致,用户看到的仍是脏数据——隔离性只管 DB 层,不管应用层

持久性≠永不丢失,要看刷盘配置

所谓“提交即永久”,前提是 Redo Log 已落盘。而是否落盘,由 innodb_flush_log_at_trx_commit 决定。别只看文档说“ACID 保证持久”,线上出问题时,往往栽在这个参数上。

  • 设为 0:崩溃前一秒提交的事务大概率丢失(log 只在 buffer,未刷盘也未交由 OS)
  • 设为 2:MySQL 挂了不丢,但 OS 崩溃或断电仍可能丢(log 在 OS cache,未 fsync 到磁盘)
  • 设为 1(默认):每次 COMMIT 都强制 fsync,最安全,但写入吞吐受限——SSD 上影响小,机械盘上明显
  • 如果用了 binlog + Redo Log 双写,配合 sync_binlog=1,才能支撑主从强一致和崩溃恢复

事务的 ACID 不是开关一开就自动生效的魔法,每个特性背后都有明确的机制、配置和使用边界。最容易被忽略的是:一致性靠代码逻辑兜底,隔离性靠锁+隔离级别协同,而持久性最终取决于你敢不敢让 Redo Log 多等那一次磁盘 IO。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

771

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

329

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

350

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1324

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

362

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

901

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

581

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

425

2024.04.29

2026赚钱平台入口大全
2026赚钱平台入口大全

2026年最新赚钱平台入口汇总,涵盖任务众包、内容创作、电商运营、技能变现等多类正规渠道,助你轻松开启副业增收之路。阅读专题下面的文章了解更多详细内容。

54

2026.01.31

热门下载

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

精品课程

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

共48课时 | 2万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 820人学习

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

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