【事务隔离级别】——深度探索数据库的事务隔离级别

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
简介: 设置事务隔离级别的方式有很多种,上篇文章中只简单提到了理论知识,这里数据库以MySQL为例,来动手设置一下事务的隔离级别并观察一下事务的隔离级别到底起到什么作用。

 设置事务隔离级别的方式有很多种,上篇文章中只简单提到了理论知识,这里数据库以MySQL为例,来动手设置一下事务的隔离级别并观察一下事务的隔离级别到底起到什么作用。


 我们都知道,每启动一下MySQL,就会获得一个数据库连接,每个数据库连接有一个全局变量@@tx_isolation,表示当前连接中事务的隔离级别。


 查看事务隔离级别


 命令行登录mysql,查看当前事务隔离级别:

 select @@tx_isolation;


  或者

select @@session.tx_isolation;


57.png


  可以看到mysql默认的事务隔离级别为REPEATABLE-READ

  查看系统全局事务离级别可以用:

select @@global.tx_isolation;


  **设置事务隔离级别**

  设置当前事务隔离级别

set session transaction isolation level repeatable read;

  设置系统全局(默认)事务隔离级别

set global transaction isolation level repeatable read;

  **read uncommitted测试**


  打开一个客户端A,并设置当前事务模式为read uncommitted(未提交读),查询表account的初始值:

58.png


  在客户端A的事务提交之前,打开另一个客户端B,更新表account:

59.png


  这时,虽然客户端B的事务还没提交,但是客户端A就可以查询到B已经更新的数据:

60.png

  一旦客户端B的事务因为某种原因回滚,所有的操作都将会被撤销,那客户端A查询到的数据其实就是脏数据:


61.png


  **read committed测试**

  针对上面的问题,把客户端A的事务隔离级别设置为read committed,再重复上面的步骤,会发现B在事务结束之前,A并不能查询到B所做的操作。

  客户端A的执行结果

62.png


  客户端B的执行结果


63.png


 但是正如上文所说,这种隔离级别下可能导致前事务中多次读取特定记录的结果不相同,比如客户端A事务隔离级别为read committed,在A的一个事务中,执行两次相同的查询,在这两次查询的中间,客户端B对数据进行更改并提交事务,那么会导致客户端A的两次查询结果不一致,导致“不可重复读”的麻烦。


 客户端A的执行结果


64.png


  客户端B的执行结果


65.png


   **repeatable read测试**

 同理,如果设置了repeatable read隔离级别,就可以保证在当前事务中多次执行相同查询的结果集相同,实现“可重复读”。


 同样以客户端A设置事务隔离级别为repeatable read为例,执行结果如下:


 客户端A的执行结果


66.png


  客户端B的执行结果

67.png


  上篇文章说到,这种隔离级别会导致“幻读”,比如客户端A中事务操作表中符合条件的若干行,同时客户端B中事务插入符合A操作条件的数据行,然后再提交。究竟会发生什么nie~~

  小编为此也进行了测试:

  客户端A的执行结果

68.png


  客户端B的执行结果


69.png

 结果却不像我们预测的那样,为客户端A中的事务设置隔离级别为repeatable read,但在客户端B中的事务插入数据后,A并没有出现“幻读”的现象。查了资料才知道,原来在mysql中,不会出现幻读。mysql的实现和标准定义的RR隔离级别有差别。


当然,

 上篇文章说到的只是SQL规范所规定的标准,不同的数据库具体的实现可能会有些差异,所以还是以实际为准~~

 实践出真知,所以每接触到一些理论知识时,最好能够实践一把,自己动手去探索,总会带给你意想不到的收货哦。


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
SQL 关系型数据库 数据库
事务隔离级别:保障数据库并发事务的一致性与性能
事务隔离级别:保障数据库并发事务的一致性与性能
|
1月前
|
算法 大数据 数据库
数据库事务:保障数据一致性的基石
数据库事务:保障数据一致性的基石
|
1月前
|
SQL 关系型数据库 MySQL
【MySQL 数据库】4、MySQL 事务学习
【MySQL 数据库】4、MySQL 事务学习
44 0
|
3月前
|
SQL Java 关系型数据库
数据库事务
数据库事务
25 0
|
24天前
|
程序员 数据库
数据库事务详解2
数据库事务详解
19 0
|
2月前
|
存储 关系型数据库 MySQL
MySQL 数据库系列(五)-----索引、事务与存储引擎(Linux版)
MySQL 数据库系列(五)-----索引、事务与存储引擎(Linux版)
28 0
|
3月前
|
SQL 关系型数据库 MySQL
Mysql高可用,索引,事务与调优:提高数据库性能的关键技术
在当今互联网时代,高可用性、稳定性和性能是数据库的三大关键要素。本文将深入探讨Mysql高可用、索引、事务和调优等方面的技术,为读者提供实用的解决方案和经验。
24 0
|
3月前
|
数据库 开发工具 Python
请解释一下云数据库的读写一致性和事务支持。
请解释一下云数据库的读写一致性和事务支持。
24 0
|
3月前
|
存储 SQL 关系型数据库
MySQL数据库进阶-事务
事务的基本概念、四大特性ACID、事务隔离级别、并发事务(脏读、幻读、不可重复读)
38 2
|
3月前
|
存储 关系型数据库 MySQL
MySQL隔离级别:提高数据库性能与数据安全的必备技能!
MySQL隔离级别:提高数据库性能与数据安全的必备技能!

热门文章

最新文章