数据库事务的 ACID 四大性质

事务的 ACID 四大性质

1. 原子性 (Atomicity)
  • 核心思想 ​: ​​"要么全部完成,要么全部不做"​。一个事务中的所有操作是一个不可分割的整体。

  • 比喻​: 就像银行转账,包含从A账户扣款和向B账户加款两个操作。原子性保证了这两个操作要么都成功执行(转账成功),要么都不执行(如果中途系统故障,不会出现A的钱扣了但B没收到的情况)。

  • 实现机制 ​: 通常由数据库的事务管理子系统日志恢复机制 共同保证。如果事务失败,系统会利用回滚日志(UNDO Log)​​ 来撤销该事务中所有已经执行的操作。

2. 一致性 (Consistency)
  • 核心思想 ​: ​事务的执行必须使数据库从一个一致的状态转换到另一个一致的状态。事务不能破坏数据库定义的任何业务规则或完整性约束(如主键唯一、外键关联、余额不能为负数等)。

  • 比喻​: 继续用转账的例子,转账前后,两个账户的总金额应该保持不变。一致性确保了不会因为转账操作而产生或消失钱。

  • 实现机制 ​: 一致性是由应用程序和数据库共同保证的。应用程序需要正确地编写事务逻辑(例如,检查余额是否足够),而数据库则通过原子性、隔离性和持久性来为一致性提供保障,并强制执行固有的完整性约束(如设置外键、非空等)。

3. 隔离性 (Isolation)
  • 核心思想 ​: ​并发执行的多个事务之间互不干扰。即使多个事务同时运行,每个事务的感觉都像是系统在单独为自己服务。

  • 比喻​: 多个用户同时操作数据库,就像每个用户都在独立的办公室裡工作,彼此看不到对方未提交的修改,从而避免了混乱。

  • 常见问题(如果没有隔离性)​​: 会产生脏读、不可重复读、幻读等问题。

  • 实现机制 ​: 数据库通过锁机制多版本并发控制(MVCC)​​ 等技术来实现不同级别的隔离性。

4. 持久性 (Durability)
  • 核心思想 ​: ​一旦事务提交,其修改就会永久保存到数据库中,即使随后系统发生任何故障(如断电、崩溃)也不会丢失。

  • 比喻​: 就像你用钢笔在纸上写字,字迹已经渗透到纸纤维里,即使用橡皮擦掉表面的墨迹,字迹依然可见(持久化在了磁盘上,而非易失的内存中)。

  • 实现机制 ​: 通常通过预写式日志(Write-Ahead Logging, WAL)​ ​ 和重做日志(REDO Log)​​ 来实现。在数据页被修改之前,先将修改操作记录到日志文件中。事务提交时,只需保证日志记录已写入持久化存储即可。即使之后数据页本身没有写回磁盘,系统重启后也能根据日志重新执行(REDO)已提交的事务,从而保证持久性。


总结与记忆技巧

性质 英文 核心保证 实现技术
原子性 Atomicity 全做或全不做 UNDO Log​(回滚日志)
一致性 Consistency 状态转换符合规则 需要应用和DB共同维护
隔离性 Isolation 并发事务互不干扰 MVCC
持久性 Durability 提交后永不丢失 REDO Log​(重做日志)
相关推荐
剩下了什么13 小时前
MySQL JSON_SET() 函数
数据库·mysql·json
山峰哥14 小时前
数据库工程与SQL调优——从索引策略到查询优化的深度实践
数据库·sql·性能优化·编辑器
较劲男子汉14 小时前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
java搬砖工-苤-初心不变14 小时前
MySQL 主从复制配置完全指南:从原理到实践
数据库·mysql
山岚的运维笔记16 小时前
SQL Server笔记 -- 第18章:Views
数据库·笔记·sql·microsoft·sqlserver
roman_日积跬步-终至千里17 小时前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
汇智信科17 小时前
打破信息孤岛,重构企业效率:汇智信科企业信息系统一体化运营平台
数据库·重构
野犬寒鸦17 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
晚霞的不甘18 小时前
揭秘 CANN 内存管理:如何让大模型在小设备上“轻装上阵”?
前端·数据库·经验分享·flutter·3d
市场部需要一个软件开发岗位19 小时前
JAVA开发常见安全问题:纵向越权
java·数据库·安全