事务___

1.什么是事务?

事务是把一组SQL语句打包为一个"整体",执行时要么执行全部,要么全部不执行(回滚)。这组SQL语句数量>=0

例如:

现在张三给李四转账100元:

执行时12,14行的语句必须都执行,否则数据出错。所以就把这两句SQL打包为一组

又比如:商品库存表和订单表

订单+1,库存-1

必须都执行

2.回滚(rollback)

如果数据库再运行过程中,在运行完12行后,突然服务器断电/系统宕机/服务器崩溃等,不能执行14行,这就会造成数据出错

所以数据库在运行过程中,进行增/删/改操作时,都会记录一个日志,记录当前操作并将其保存在硬盘上

如果事务正常执行完毕,保存的日志就会删除

如果事务执行一半异常退出,日志就会保存到硬盘上

重启MySQL服务器,就会读取日志中的内容,查看之前的操作。然后根据之前的操作,把硬盘保存的数据还原回去

3.事物的ACID特性

1.A(Atomicity)

原子性

把事务当作不可再分的"原子"

即一个事务中的所有操作,要么全部成功,要么全部失败,不会出现执行了一半这样的情况。如果在事务执行中发生错误,会回滚会事务开始前状态

2.C(Consistency)

一致性

在事务开始之前和事务结束以后,数据库的完整性不会被破坏。这表示写入的数据必须完全符合所有的预设规则,包括数据的精度、关联性以及关于事务执行过程中服 务器崩溃后如何恢复。

比如转账。必须是你-500,他+500,不能是你-500,他+0

3.I(Isolation)

隔离性

一个数据库服务器可以同时执行多个客户端提交的事务,并且事物之间不会相互影响。数据库允许多个事务同时并发,同时对数据进行读写和修改,隔离性可以防止多个事务并发执行时交叉执行导致数据不一致的问题。

事务隔离可以指定不同级别

4.D(Durabilty)

持久性

事务对数据做出的修改,都是持久的。数据保存在硬盘上,重启服务器,重启数据库,都不会使数据丢失

相关推荐
辞旧 lekkk38 分钟前
【Qt】信号和槽
linux·开发语言·数据库·qt·学习·mysql·萌新
zc.z40 分钟前
JAVA实现:纯PCM格式音频转换成BASE64
java·音视频·pcm
mask哥1 小时前
力扣算法java实现汇总整理(上)
java·算法·leetcode
2301_809204702 小时前
JavaScript中严格模式use-strict对引擎解析的辅助.txt
jvm·数据库·python
zjy277772 小时前
mysql如何选择合适的索引类型_mysql索引设计实战
jvm·数据库·python
Aaswk2 小时前
Java Lambda 表达式与流处理
java·开发语言·python
是宇写的啊2 小时前
Spring AOP
java·spring
笨蛋不要掉眼泪2 小时前
Mysql架构揭秘:update语句的执行流程
数据库·mysql·架构
万邦科技Lafite3 小时前
京东item_get接口实战案例:实时商品价格监控全流程解析
java·开发语言·数据库·python·开放api·淘宝开放平台
秋93 小时前
ruoyi项目更换为mysql9.7.0数据库
数据库