MySQL事务介绍

本文详细介绍了MySQL事务的四大特性:原子性、一致性、隔离性和持久性,以及四种隔离级别:读未提交、读提交、可重复读和串行化。重点讨论了InnoDB引擎下MVCC的实现,包括Read View和undo log版本链,并分析了长事务的问题及优化策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、什么是事务?

事务就是要保证一组数据库操作,要么全部成功,要么全部失败。在 MySQL 中,事务支持是在引擎层实现的。

MySQL 是一个支持多引擎的系统,但并不是所有的引擎都支持事务。比如 MySQL 原生的 MyISAM 引擎就不支持事务,这也是 MyISAM 被 InnoDB 取代的重要原因之一。

2、事务特性

2.1、原子性(Atomicity)

事务中的所有操作要么全部成功,要么全部失败。

2.2、一致性(consistency)

事务开始前和事务结束后,数据库的完整性约束没有被破坏。如果事务中某个操作失败了,系统可以撤销事务,回滚到事务前的状态。

2.3、隔离性(Isolation)

每个读写事务的对象对其他事务的操作对象能相互分离,即该事物提交前对其他事务不可见。

2.4、持久性(durability)

事务一旦提交,结果就是永久性的。即使发生宕机,数据库也能

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

明天争取

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值