开发者社区> 推荐码发放> 正文

Mysql 事务隔离级别 与 读出现的问题实验

简介: Mysql 事务隔离级别 与 读出现的问题实验 读未提交:一个事务的隔离级别为‘读未提交’,它可以读取其他事务未提交的数据 读已提交:一个事务的隔离级别为‘读已提交’,它只可以读其他事务已提交的数据 可重复读:一个事务的隔离级别为‘可重复读’,不关心其他事务的操作,整个事务内读取的数据一致。
+关注继续查看

Mysql 事务隔离级别 与 读出现的问题实验

读未提交:一个事务的隔离级别为‘读未提交’,它可以读取其他事务未提交的数据
读已提交:一个事务的隔离级别为‘读已提交’,它只可以读其他事务已提交的数据
可重复读:一个事务的隔离级别为‘可重复读’,不关心其他事务的操作,整个事务内读取的数据一致。


可能会出现幻读。
事务1: 可重复读
+-----------------+
| @@tx_isolation |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set, 1 warning (0.00 sec)
事务2:可重复读
mysql> select @@tx_isolation;
+-----------------+
| @@tx_isolation |
+-----------------+
| REPEATABLE-READ |
+-----------------+
1 row in set, 1 warning (0.00 sec)
事务1: 开启事务,查询,
mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from account;
+----+------+------+
| id | name | age |
+----+------+------+
| 1 | aa | NULL |
| 2 | bb | NULL |
| 3 | cc | NULL |
| 4 | dd | NULL |
+----+------+------+
4 rows in set (0.00 sec)
事务2:开启事务,查询,插入,查询,提交事务
mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from account;
+----+------+------+
| id | name | age |
+----+------+------+
| 1 | aa | NULL |
| 2 | bb | NULL |
| 3 | cc | NULL |
| 4 | dd | NULL |
+----+------+------+
4 rows in set (0.00 sec)
mysql> insert into account (id, name) values(5, 'ee');
Query OK, 1 row affected (0.00 sec)
mysql> select * from account;
+----+------+------+
| id | name | age |
+----+------+------+
| 1 | aa | NULL |
| 2 | bb | NULL |
| 3 | cc | NULL |
| 4 | dd | NULL |
| 5 | ee | NULL |
+----+------+------+
5 rows in set (0.00 sec)
mysql> commit;
Query OK, 0 rows affected (0.00 sec)
事务1:查询,插入
mysql> select * from account;
+----+------+------+
| id | name | age |
+----+------+------+
| 1 | aa | NULL |
| 2 | bb | NULL |
| 3 | cc | NULL |
| 4 | dd | NULL |
+----+------+------+
4 rows in set (0.00 sec)
mysql> insert into account (id, name) values(5, 'ee');
ERROR 1062 (23000): Duplicate entry '5' for key 'PRIMARY'
事务1没有查询到 (5, 'ee')这条,但在插入的时候,报错:重复


可串型化:一个事务的隔离级别为‘可串型化’,对自己关心的数据加上锁,别的事务在操作这些数据的时候会等待,直到‘可串型化’事务提交。


事务3:可串型化,开启事务,查询
mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from account;
+----+------+------+
| id | name | age |
+----+------+------+
| 1 | aa | NULL |
| 2 | bb | NULL |
| 3 | cc | NULL |
| 4 | dd | NULL |
| 5 | ee | NULL |
+----+------+------+
5 rows in set (0.00 sec)
事务2:查询,插入
mysql> select * from account;
+----+------+------+
| id | name | age |
+----+------+------+
| 1 | aa | NULL |
| 2 | bb | NULL |
| 3 | cc | NULL |
| 4 | dd | NULL |
| 5 | ee | NULL |
+----+------+------+
5 rows in set (0.00 sec)
mysql> insert into account (id, name) values(6, 'ff');
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
mysql> update account set age=10 where name='aa';
‘可串型化’事务,对自己关心的数据加锁,不允许修改

// session 1: 开启事物、查询、更新某一行、查询
mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)
mysql> select * from book;
+--------+------+
| bookid | card |
+--------+------+
| 23 | 2 |
| 10 | 3 |
| 6 | 4 |
| 16 | 4 |
| 9 | 5 |
| 4 | 6 |
| 14 | 6 |
| 3 | 7 |
| 8 | 7 |
| 20 | 7 |
| 1 | 9 |
| 5 | 9 |
| 12 | 10 |
| 17 | 10 |
| 2 | 12 |
| 13 | 12 |
| 7 | 16 |
| 19 | 16 |
| 15 | 17 |
| 18 | 17 |
| 11 | 20 |
+--------+------+
21 rows in set (0.00 sec)
mysql> update book set card = 3 where bookid = 23;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> select * from book;
+--------+------+
| bookid | card |
+--------+------+
| 10 | 3 |
| 23 | 3 |
| 6 | 4 |
| 16 | 4 |
| 9 | 5 |
| 4 | 6 |
| 14 | 6 |
| 3 | 7 |
| 8 | 7 |
| 20 | 7 |
| 1 | 9 |
| 5 | 9 |
| 12 | 10 |
| 17 | 10 |
| 2 | 12 |
| 13 | 12 |
| 7 | 16 |
| 19 | 16 |
| 15 | 17 |
| 18 | 17 |
| 11 | 20 |
+--------+------+
21 rows in set (0.00 sec)
// session 2: 查询、更新其他行、更新 session 1操作的行
mysql> select * from book;
+--------+------+
| bookid | card |
+--------+------+
| 23 | 2 |
| 10 | 3 |
| 6 | 4 |
| 16 | 4 |
| 9 | 5 |
| 4 | 6 |
| 14 | 6 |
| 3 | 7 |
| 8 | 7 |
| 20 | 7 |
| 1 | 9 |
| 5 | 9 |
| 12 | 10 |
| 17 | 10 |
| 2 | 12 |
| 13 | 12 |
| 7 | 16 |
| 19 | 16 |
| 15 | 17 |
| 18 | 17 |
| 11 | 20 |
+--------+------+
21 rows in set (0.00 sec)
mysql> update book set card = 2 where bookid =10;
Query OK, 1 row affected (0.09 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> update book set card = 2 where bookid =23;
ERROR 1205 (HY000): Lock wait timeout exceeded; try restarting transaction
Innodb 默认为行锁,一个shiwu

 原文地址https://blog.csdn.net/wjb214149306/article/details/82431042

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
RocketMQ与MYSQL事务消息整合
rocketmq事务消息与mysql事物整合
8655 0
事务隔离级别
尽管数据库为用户提供了锁的DML操作方式,但直接使用锁管理是非常麻烦的,因此数据库为用户提供了自动锁机制。只要用户指定会话的事务隔离级别,数据库就会分析事务中的SQL语句,然后自动为事务操作的数据资源添加上适合的锁。
893 0
事务隔离级别|学习笔记
快速学习事务隔离级别
54 0
关于MySQL事务的简单讲解
事务的隔离性由锁来实现。原子性、一致性、持久性通过数据库的redo log和undo log来实现。redo log称为重做日志,用来保证事务的原子性和持久性,undo log用来保证事务的一致性。
5271 0
MySQL---数据库从入门走向大神系列(六)-事务处理与事务隔离(锁机制)
MySQL 事务处理 简单介绍事务处理: MySQL 事务主要用于处理操作量大,复杂度高的数据。 比如说,在人员管理系统中,你删除一个人员,你即需要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等等,这样,这些数据库操作语句就构成一个事务! 一个事务是一个连续的一组数据库操作,就好像它是一个单一的工作单元进行。
1226 0
MySQL事务的艺术和陷阱
作者在之前的文章 “MySQL事务及为何不能在PHP模仿事务” 里面, 详细说明了事务的优点,并介绍了一些简单的SQL命令,使得应用程序更加健壮。但在web程序员的生命旅程中并没有多少事情是看起来那样简单的。
656 0
Java提升篇-事务隔离级别和传播机制
问题的提出 为了保证并发操作数据的正确性及一致性,SQL规范于1992年提出了数据库事务隔离级别。 事务隔离级别分类 事务隔离级别由低往高可分为以下几类 READ UNCOMMITTED,读取未提交的数据。
1054 0
+关注
推荐码发放
阿里云优惠码阿里云推荐券bieryun.com
381
文章
5
问答
文章排行榜
最热
最新