【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的余额仍然会反映转账结果。

相关推荐
rising start1 天前
二、全面理解MySQL架构
mysql·架构
星星也在雾里1 天前
PgBouncer 解决 PostgreSQL 连接数超限 + 可视化监控
数据库·postgresql
bqq198610261 天前
MySQL性能优化
mysql·mysql优化
雨辰AI1 天前
SpringBoot3 + 人大金仓读写分离 + 分库分表 + 集群高可用 全栈实战
java·数据库·mysql·政务
长城20241 天前
关于MySql的ONLY_FULL_GROUP_BY问题
数据库·mysql·聚合列
常常有1 天前
MySQL 底层执行原理:输入SQL语句到两阶段提交
数据库·sql·mysql
Mr. zhihao1 天前
深入解析redis基本数据结构
数据结构·数据库·redis
m0_748839491 天前
利用天正暖通CAD快速掌握风管数量统计的方法
数据库
随身数智备忘录1 天前
什么是设备管理体系?设备管理体系包含哪些核心模块?
网络·数据库·人工智能
海市公约1 天前
MySQL更新语句执行全流程:从Buffer Pool修改到二阶段提交
数据库·mysql·binlog·innodb·undo log·二阶段提交·update执行原理