我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Mysql事务隔离级别之读提交的示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Mysql事务隔离级别之读提交的示例分析

这篇文章主要为大家展示了“Mysql事务隔离级别之读提交的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Mysql事务隔离级别之读提交的示例分析”这篇文章吧。

查看mysql 事务隔离级别

mysql> show variables like '%isolation%';
+---------------+----------------+
| Variable_name | Value     |
+---------------+----------------+
| tx_isolation | READ-COMMITTED |
+---------------+----------------+
1 row in set (0.00 sec)

可以看到当前的事务隔离级别为 READ-COMMITTED 读提交

下面看看当前隔离级别下的事务隔离详情,开启两个查询终端A、B。

下面有一个order表,初始数据如下

mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |   1 |
+----+--------+
1 row in set (0.00 sec)

第一步,在A,B中都开启事务

mysql> start transaction;
Query OK, 0 rows affected (0.00 sec)

第二步查询两个终端中的number值

A

 mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |   1 |
+----+--------+
1 row in set (0.00 sec)

B

 mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |   1 |
+----+--------+
1 row in set (0.00 sec)

第三步将B中的number修改为2,但不提交事务

mysql> update `order` set number=2;
Query OK, 1 row affected (0.00 sec)
Rows matched: 1 Changed: 1 Warnings: 0

第四步查询A中的值

mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |   1 |
+----+--------+
1 row in set (0.00 sec)

发现A中的值并没有修改。

第五步,提交事务B,再次查询A中的值

B

mysql> commit;
Query OK, 0 rows affected (0.01 sec)

A

mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |   2 |
+----+--------+
1 row in set (0.00 sec)

发现A中的值已经更改

第六步,提交A中的事务,再次查询A,B的值。

A

mysql> commit;
Query OK, 0 rows affected (0.00 sec)

mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |   2 |
+----+--------+
1 row in set (0.00 sec)

B

mysql> select * from `order`;
+----+--------+
| id | number |
+----+--------+
| 13 |   2 |
+----+--------+
1 row in set (0.00 sec)

发现A,B中的值都更改为2了。

下面给一个简单的示意图

Mysql事务隔离级别之读提交的示例分析

我们可以看到,在事务隔离级别为读已提交 的情况下,当B中事务提交了之后,即使A未提交也可以读到B事务提交的结果。这样解决了脏读的问题。

以上是“Mysql事务隔离级别之读提交的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Mysql事务隔离级别之读提交的示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

MySQL中隔离级别的示例分析

这篇文章主要介绍MySQL中隔离级别的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!MySQL入门--事务隔离级别1) 隔离级别介绍如果一个客户机的事务更改了数据,其他客户机的事务是应发现这些更改还是应与其隔
2023-06-01

Mysql事务隔离级别原理实例解析

引言 大家在面试中一定碰到过 说说事务的隔离级别吧? 老实说,事务隔离级别这个问题,无论是校招还是社招,面试官都爱问!然而目前网上很多文章,说句实在话啊,我看了后我都怀疑作者弄懂没!因为他们对可重复读(Repeatable Read)和串行
2022-05-29

mysql中的事务隔离级别及可重复读读提交详细分析(mvcc多版本控制/undo log)

一.事物隔离级别读未提交(read uncommitted)是指,一个事务还没提交时,它做的变更就能被别的事务看到.通俗理解,别人改数据的事务尚未提交,我在我的事务中也能读到。读提交(read committed)是指,一个事务提交之后,它做的变更才会被其他事
mysql中的事务隔离级别及可重复读读提交详细分析(mvcc多版本控制/undo log)
2015-03-04

MySQL事务隔离级别与相关示例(脏读、不可重复读、幻读)

MySQL8中隔离级别的变量跟之前的版本不一样,之前是tx_isolation,MySQL8改成了transaction_isolation。查看当前隔离级别的命令是mysql> select @@global.transaction_isolation,@@
MySQL事务隔离级别与相关示例(脏读、不可重复读、幻读)
2019-11-12

MySQL事务隔离实现并发控制的示例分析

这篇文章主要介绍了MySQL事务隔离实现并发控制的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、并发访问控制实现的并发访问的控制技术是基于锁;锁分为表级锁和行级锁
2023-06-20

MySQL查看和修改事务隔离级别的实例讲解

查看事务隔离级别 在 MySQL 中,可以通过show variables like '%tx_isolation%'或select @@tx_isolation;语句来查看当前事务隔离级别。 查看当前事务隔离级别的 SQL 语句和运行结果
2022-05-29

MySQL脏读幻读不可重复读及事务的隔离级别和MVCC、LBCC实现

目录前言事务因并发出现的问题有哪些 脏读不可重复读幻读不可重复读与幻读的区别事务的四个隔离级别InnoDB默认的隔离级别是RRRead UnCommited 读未提交 RURead Commited 读已提交 RCRepeatable Re
2022-07-11

深入解析数据库事务隔离级别:揭示数据一致性之谜

事务隔离级别是数据库系统中一个重要的概念,通过了解数据库事务隔离级别,可以更轻松地保证数据库数据的安全性与一致性。
深入解析数据库事务隔离级别:揭示数据一致性之谜
2024-02-25

深入解析数据库事务隔离级别:理解不同等级之间的差异

数据库事务隔离级别是控制并发事务如何访问和修改数据库的关键机制。通过了解不同隔离级别之间的差异,可以帮助您选择最适合应用程序需求的级别。
深入解析数据库事务隔离级别:理解不同等级之间的差异
2024-02-23

数据库事务隔离级别深入剖析:揭示数据一致性背后的秘密

事务隔离级别是数据库用来保证数据一致性和完整性的关键机制,本文将深入剖析不同事务隔离级别下的行为,并提供演示代码,帮助您理解事务隔离级别的作用和重要性。
数据库事务隔离级别深入剖析:揭示数据一致性背后的秘密
2024-02-23

编程热搜

目录