本文导读
本文介绍MySQL事务的使用和其存在长事务的风险, MySQL 的事务及其特性,并发事务带来的问题、事务的隔离级别与演示,单版本控制锁以及多版本并发控制 MVCC。
一、MySQL事务使用
1、什么是事务
事务是作为单个逻辑工作单元执行的一系列操作。这些操作要么全部,要么没有,是一个不可分割的工作单元。
例如,购买东西支付的过程中会有一系列操作,如查询余额、加减、更新余额。这些操作必须是同时的。否则,显示你支付成功,但是系统没有收到钱
在MySQL中,事务支持是在引擎层实现的,MyISAM引擎不支持事务
2、事务的四个特性
要成为事务,逻辑工作单元必须满足关系数据库管理系统中的四个特征。
即所谓的ACID:原子性、一致性、隔离性、持久性。
原子性:事务的所有操作要么完成要么未完成,不会在中间阶段结束。
一致性:在事务之前和之后,数据库的完整性限制不会被打破。
隔离性:当多个事务同时访问数据库中的同一数据时,将显示关系。
持久性:事务完成后,事务所做的更改将持久保存,不会丢失。
ACID 需要通过 Redo 和 Undo 日志来保证。MySQL日志系统详解:(后续补充)
3、MySQL事务使用
MySQL 的事务启动方式有以下2种:
3.1、显式启动事务语句
begin 或 start transaction。配套的提交语句是 commit,回滚语句是 rollback。
BEGIN -- 开启事务
START TRANSACTION -- 开启事务
INSERT INTO fork_business_detail VALUES ( 4, '123', '123', '123004', '2022-11-12 17:17:29', '1', &#