MySQL事务和事务的四种隔离级别 for INNODB
admin
2023-02-26 04:40:38
0

什么是事务

一组原子性的SQL语句,可以提交或回滚的原子工作单元 。当事务对数据库进行多次更改时,要么在提交事务后所有更改成功,要么在回滚事务时撤消所有更改。

事务特性

ACID特性
  • A: atomicity(原子性):整个事务中的所有操作要么全部成功,要么全部失败后回滚;
  • C: consistency(一致性):整个数据库总是从一个一致性状态转换为另一个一致性状态;
  • I: isolation(隔离性):一个事务所做的的操作在提交之前,是不被其它事务所见的;
  • D: durability(持久性):事务一旦提交,其所做的修改会永久保存于数据库中。
事务生命周期

MySQL事务和事务的四种隔离级别 for INNODB

事务管理

显式启动事务:
BEGIN
BEGIN WORK
START TRANSACTION
结束事务:
# 提交
COMMIT
# 回滚
ROLLBACK
注:只有事务型的存储引擎的DML语句才能支持此类操作
自动提交:
默认为1,为0时设为非自动提交
> show variables like 'autocommit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| autocommit    | ON    |
+---------------+-------+
1 row in set (0.00 sec)

set autocommit={1|0}
注:建议显式请求和提交事务,而不要使用“自动提交”功能。
事务支持保存点:
SAVEPOINT identifier
ROLLBACK [WORK] TO [SAVEPOINT] identifier
RELEASE SAVEPOINT identifier
查看事务:
# 查看当前的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX;
#查看当前锁定的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;
#查看当前等锁的事务
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;

事务隔离级别

MySQL事务支持四种隔离级别,从上至下更加严格
事务隔离级别 说明 脏读可能性 不可重复读可能性 幻读可能性 加读锁
READ UNCOMMITTED 可读取到未提交数据,产生脏读 Yes Yes Yes No
READ COMMITTED 可读取到提交数据,但未提交数据不可读,产生不可重复读,即可读取到多个提交数据,导致每次读取的数据不一致 No Yes Yes No
REPEATABLE READ 可重复读,多次读取数据都一致,产生幻读,即读取过程中,即使有其它提交的事务修改数据,仍只能读取到未修改前的旧数据。此为MySQL默认设置 Yes Yes Yes No
SERIALIZABLE 可串行化,未提交的读事务阻塞修改事务(加读锁,但不阻塞读事务),或者未提交的修改事务阻塞读事务(加写锁,其它事务的读,写都不可以执行)。会导致并发性能差 No No No Yes

MVCC和事务的隔离级别

MVCC(多版本并发控制机制)只在REPEATABLE READ和READ COMMITTED两个隔离级别下工作。其他两个隔离级别都和MVCC不兼容,因为READ UNCOMMITTED总是读取最新的数据行,而不是符合当前事务版本的数据行。而SERIALIZABLE则会对所有读取的行都加锁

如何指定事务隔离级别

参考:https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html#sysvar_tx_isolation
1.系统变量tx_isolation指定,默认为REPEATABLE-READ,有效范围:Global, Session
# 语法:
set tx_isolatioin='value';
# 有效值
READ-UNCOMMITTED
READ-COMMITTED
REPEATABLE-READ
SERIALIZABLE
2.服务器选项中指定
在/etc/my.cnf文件的[mysqld]块中使用transaction-isolation选项设置
[mysqld]
transaction-isolation = value

事务隔离级别验证

背景:通过两个终端显示启动两个事务来验证,用作验证的user表的表内容和表结构如下
mysql> desc user;
+-------+------------------+------+-----+---------+----------------+
| Field | Type             | Null | Key | Default | Extra          |
+-------+------------------+------+-----+---------+----------------+
| id    | int(10) unsigned | NO   | PRI | NULL    | auto_increment |
| name  | varchar(30)      | NO   |     | NULL    |                |
+-------+------------------+------+-----+---------+----------------+
2 rows in set (0.00 sec)

mysql> select * from user;
+----+-------+
| id | name  |
+----+-------+
|  2 | root  |
|  3 | admin |
+----+-------+
2 rows in set (0.00 sec)
1.READ UNCOMMITTED级别

MySQL事务和事务的四种隔离级别 for INNODB

2.READ COMMITTED级别

MySQL事务和事务的四种隔离级别 for INNODB

3.REPEATABLE READ级别

MySQL事务和事务的四种隔离级别 for INNODB

4.SERIALIZABLE级别
未提交的读事务阻塞修改事务(加读锁,但不阻塞读事务)

MySQL事务和事务的四种隔离级别 for INNODB

未提交的修改事务阻塞读事务(加写锁,其它事务的读、写都不可以执行)

MySQL事务和事务的四种隔离级别 for INNODB

注:此种事务隔离级别会导致并发性能差。

附加案例:如果一个事务产生了写锁,然后一直未结束事务,这样会导致其它事务的读、写都不可以执行,对于这种情况,可以找到未结束并且导致阻塞的事务,手动将其kill。

拿上面未提交的修改事务阻塞读事务的案例来验证

MySQL事务和事务的四种隔离级别 for INNODB

打开第三个会话执行以下操作

MySQL事务和事务的四种隔离级别 for INNODB
MySQL事务和事务的四种隔离级别 for INNODB

死锁

MySQL事务和事务的四种隔离级别 for INNODB

相关内容

热门资讯

意大利向印尼赠送退役航母,一场... 澎湃新闻特约撰稿 林森据环球时报4月30日援引外媒报道,意大利议会4月28日批准政府的一项计划,将退...
特朗普:即便油价涨到200美元... 伊朗战争爆发搅乱全球能源供应,油价高涨,美国国内许多人苦不堪言。但是美国总统特朗普说,即便油价涨到2...
泽连斯基称乌方将“对等”回应俄... 新华社基辅5月6日电(记者李东旭) 乌克兰总统泽连斯基6日晚在社交媒体发文称,自6日凌晨以来,俄方以...
人民日报刊文:扫码用餐 吃得“... 河南信阳推进公务接待改革扫码用餐 吃得“明白”(厉行节约 反对浪费)本报记者 王乐文 毕京津《人民日...
活动回顾:心灵律动·刚柔共生 心灵律动 - 活动回顾 - “五一”期间, 东莞市工人文化宫连续举办了两场 “心灵律动·刚柔共生”心...
商业航天政策利好 全国首个卫星... 来源:21世纪经济报道 21世纪经济报道记者周慧 5月6日,工业和信息化部官网消息称,工业和信息化部...
伊朗确认前往美国参加世界杯:将... 当地时间5月6日,伊朗国家足球队主教练在接受采访时表示,伊朗国家足球队将于美加墨世界杯开始前14天抵...
雷达、机库、营房、燃料库、飞机... 据《华盛顿邮报》5月6日报道,通过卫星影像分析发现,自2月28日战事爆发以来,伊朗空袭已在中东美军军...
从买买买到租租租,“租用一代”... “五一”假期还在路上,年轻人已经“租”起来了。 “租三天,不到300块钱。”五一放假前一周,清清已给...
【品牌】摩托罗拉大折叠屏新机定... 此前联想预热将于5月19日19点举行联想天禧AI一体多端全场景新品超能之夜活动,届时将带来多款新品,...