事务___

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)

持久性

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

相关推荐
justjinji2 小时前
如何批量更新SQL数据表_使用UPDATE JOIN语法提升效率
jvm·数据库·python
北漂Zachary2 小时前
四大编程语言终极对比
android·java·php·laravel
小江的记录本2 小时前
【网络安全】《网络安全常见攻击与防御》(附:《六大攻击核心特性横向对比表》)
java·网络·人工智能·后端·python·安全·web安全
爱学习的小邓同学2 小时前
MySQL --- MySQL数据类型
数据库·mysql
weixin_580614002 小时前
MySQL存储过程中如何防止SQL注入_使用参数化查询规范
jvm·数据库·python
2401_837163892 小时前
PHP源码开发用台式机还是笔记本更合适_硬件选型对比【方法】
jvm·数据库·python
baidu_340998823 小时前
mysql修改列名会导致程序报错吗_Change Column语法与兼容性
jvm·数据库·python
只说证事3 小时前
会计岗位向管理会计升级,最该补哪些数据分析技能
数据库·数据挖掘·数据分析
嗑嗑嗑瓜子的猫3 小时前
Java!它值得!
java·开发语言