数据库事务的 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​(重做日志)
相关推荐
李广坤1 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
爱可生开源社区2 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1772 天前
《从零搭建NestJS项目》
数据库·typescript
加号33 天前
windows系统下mysql多源数据库同步部署
数据库·windows·mysql
シ風箏3 天前
MySQL【部署 04】Docker部署 MySQL8.0.32 版本(网盘镜像及启动命令分享)
数据库·mysql·docker
李慕婉学姐3 天前
Springboot智慧社区系统设计与开发6n99s526(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
百锦再3 天前
Django实现接口token检测的实现方案
数据库·python·django·sqlite·flask·fastapi·pip
tryCbest3 天前
数据库SQL学习
数据库·sql
jnrjian3 天前
ORA-01017 查找机器名 用户名 以及library cache lock 参数含义
数据库·oracle
十月南城3 天前
数据湖技术对比——Iceberg、Hudi、Delta的表格格式与维护策略
大数据·数据库·数据仓库·hive·hadoop·spark