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

相关推荐
tianyuanwo2 小时前
RPM数据库锁竞争:原理、诊断与根治方案
数据库·rpm·bdb·命令挂起
TG:@yunlaoda360 云老大2 小时前
如何评估华为云国际站代理商跨境合规要求?
大数据·数据库·华为云·云计算
志凌海纳SmartX2 小时前
银行核心系统备库“降本增效”探索:超融合承载Oracle ADG备库的测试验证
数据库·oracle
木卫二号Coding2 小时前
POSTGRESQL+数据库备份与还原
数据库·postgresql·oracle
Lvan的前端笔记2 小时前
python:用 dotenv 管理环境变量&生产环境怎么管理环境变量
网络·数据库·python
云老大TG:@yunlaoda3602 小时前
如何通过华为云国际站代理商OBS实现数据跨境传输与分发加速?
数据库·华为云·php
梓仁沐白2 小时前
CSAPP-Archlab
数据库·windows
-大头.2 小时前
SQL性能优化与索引策略实战
数据库·sql·性能优化
张人玉3 小时前
c# Data相关类
数据库·oracle