【MySQL 事务】详细介绍+实例

1.数据库事务

事务是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或 撤销操作请求,即这些操作要么同时成功,要么同时失败。

2.单个逻辑单元

在数据库事务的上下文中,单个逻辑单元表示在事务中的一系列操作,它们是一个完整的功能,必须作为一个 整体来执行,如果其中任何一个操作失败,整个事务都会回滚,确保数据的完整性和一致性。

3.事务的概念

事务(transaction) 是作为一个单元的一组有序的数据库操作。如果组中的所有操作都成功,则认为事务 成功,即使只有一个操作失败, 事务也不成功。如果所有操作完成,事务则提交,其修改将作用于所有其他 数据库进程。如果一个操作失败,则事务将回滚,该事务所有操作的影响都将取消。

4.事务的四大特性

原子性(Atomicity):事务是不可分割的最小操作单元,要么同时成功,要么同时失败。

一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态。

隔离性(Isolation):数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行。

持久性(Durability):事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。

5.对四种特性的理解+举例说明

原子性(Atomicity):事务是不可分割的最小操作单元,要么同时成功,要么同时失败。

事务:从账户A转账100元到账户B。

操作: 从账户A扣除100元。 向账户B增加100元。

如果第二步失败(例如账户B不存在),则第一步也会回滚,账户A的余额不会减少。

一致性(Consistency):事务完成时,必须使所有的数据都保持一致状态。

转账前:账户A余额1000元,账户B余额500元,总余额1500元。

转账后:账户A余额900元,账户B余额600元,总余额仍为1500元。

如果转账过程中总余额发生变化(例如账户A扣款但账户B未到账),则数据库会回滚事务以保持一致性。

隔离性(Isolation):数据库系统提供的隔离机制,保证事务在不受外部并发操作影响的独立环境下运行。

事务1:从账户A转账100元到账户B。

事务2:从账户A转账200元到账户C。

如果没有隔离性,事务2可能会读取事务1未提交的数据,导致脏读或丢失更新。

持久性(Durability):事务一旦提交或回滚,它对数据库中的数据的改变就是永久的。

事务提交后,账户A的余额减少100元,账户B的余额增加100元。

即使数据库服务器在提交后立即崩溃,重启后账户A和账户B的余额仍然会反映转账结果。

相关推荐
NineData17 小时前
数据库迁移总踩坑?用 NineData 迁移评估,提前识别所有兼容性风险
数据库·程序员·云计算
赵渝强老师19 小时前
【赵渝强老师】PostgreSQL中表的碎片
数据库·postgresql
全栈老石1 天前
拆解低代码引擎核心:元数据驱动的"万能表"架构
数据库·低代码
倔强的石头_2 天前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
jiayou643 天前
KingbaseES 实战:深度解析数据库对象访问权限管理
数据库
于眠牧北3 天前
MySQL的锁类型,表锁,行锁,MVCC中所使用的临键锁
mysql
李广坤4 天前
MySQL 大表字段变更实践(改名 + 改类型 + 改长度)
数据库
Turnip12025 天前
深度解析:为什么简单的数据库"写操作"会在 MySQL 中卡住?
后端·mysql
爱可生开源社区5 天前
2026 年,优秀的 DBA 需要具备哪些素质?
数据库·人工智能·dba
随逸1775 天前
《从零搭建NestJS项目》
数据库·typescript