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

相关推荐
0xDevNull3 小时前
MySQL数据冷热分离详解
后端·mysql
科技小花4 小时前
数据治理平台架构演进观察:AI原生设计如何重构企业数据管理范式
数据库·重构·架构·数据治理·ai-native·ai原生
一江寒逸4 小时前
零基础从入门到精通MySQL(中篇):进阶篇——吃透多表查询、事务核心与高级特性,搞定复杂业务SQL
数据库·sql·mysql
D4c-lovetrain4 小时前
linux个人心得22 (mysql)
数据库·mysql
阿里小阿希4 小时前
CentOS7 PostgreSQL 9.2 升级到 15 完整教程
数据库·postgresql
荒川之神4 小时前
Oracle 数据仓库雪花模型设计(完整实战方案)
数据库·数据仓库·oracle
做个文艺程序员5 小时前
MySQL安全加固十大硬核操作
数据库·mysql·安全
不吃香菜学java5 小时前
Redis简单应用
数据库·spring boot·tomcat·maven
一个天蝎座 白勺 程序猿5 小时前
Apache IoTDB(15):IoTDB查询写回(INTO子句)深度解析——从语法到实战的ETL全链路指南
数据库·apache·etl·iotdb
不知名的老吴5 小时前
Redis的延迟瓶颈:TCP栈开销无法避免
数据库·redis·缓存