最近在复习MySQL事务,但网上很多博客和资料可以说讲的不是模棱两可就是只有文字描述不够形象易懂,下面通过我的学习来详细讲一讲事务并发都会引起哪些问题?以及隔离级别是什么?InnoDB引擎是如何通过隔离级别来解决并发事务所引起的问题?



何为读已提交

(相当于当前读,也就是这种隔离级别下只要有其他事务对数据进行更改的操作且提交,那么当前事务Select就会查询到最新的数据)

从字面上我们就可以理解,即一个事务操作过程中可以读取到其他事务已经提交的数据。

事务中的每次读取操作,读取到的都是数据库中其他事务已提交的最新的数据(相当于当前读),也就是不能读取到其他事务还未提交的数据,所以在读已提交这个隔离级别下就解决了脏读的问题

何为可重复读

(又称快照读,当事务A开启时便对数据产生一个快照,与此同时无论其他事务对数据如何操作,在当前这个事务A里查询到的都是快照中的数据)(又称快照读,当事务A开启时便对数据产生一个快照,与此同时无论其他事务对数据如何操作,在当前这个事务A里查询到的都是快照中的数据)

一个事务操作中对于一个读取操作不管多少次,读取到的结果都是一样的。所以在可重复读这个隔离级别下就解决了一个事务当中前后读取到的结果不一致的情况,从而解决了不可重复读的问题

下面就通过实际操作来看看脏读,不可重复读,幻读这三个现象是什么样的,以及在InnoDB各个隔离级别下是如何解决了这些并发事务问题的。

脏读现象:

首先设置隔离级别为未提交读

打开两个窗口,同时执行事务A和B



此时事务B更新数据后并未提交,但可以看到事务A前后查询到的数据不一样,也就是读取到了其他事务还未提交的数据,这也就是脏读的现象

如何解决脏读现象:

首先设置隔离级别为已提交读:

打开两个窗口,同时执行事务A和B:





上述流程可以看到当隔离级别为已提交读时,已经解决了脏读的情况,但是当事务B对数据进行更改且提交时,事务A却出现了前后的查询结果不一致的情况,这种现象就叫做不可重复读。

如何解决不可重复读的现象:

首先设置隔离级别为可重复读:

打开两个窗口,同时执行事务A和B:





上述流程可以看到当隔离级别为可重复读时,已经解决了不可重复读的情况,当事务B对数据进行更改且提交时,事务A前后的查询结果一致,只有当事务A提交后再开启事务查询时才会查到最新的数据。

幻读现象:

首先设置隔离级别为可重复读:

打开两个窗口,同时执行事务A和B:



上述流程可以看到当隔离级别为可重复读时,事务A,B同时执行,事务A先查询到id=3是没有数据的于是想要Insert,此时事务B也insert了id=3的数据但是事务A却查询不到,并且当事务A insert的时候却提示了error,这种现象就称为幻读。

如何解决幻读的现象:

首先设置隔离级别为串行化:

打开两个窗口,同时执行事务A和B:







上述流程可以看到当隔离级别为序列化时,事务A,B同时执行,事务A先查询到id=4是没有数据,此时事务B想insert id=4的数据但是却阻塞了,接下来事务A执行了insert id=4d的操作,并且只要事务A不提交事务B都一直处于阻塞状态中,当事务A提交后事务B才不再阻塞,但此时却报错提示id=4已存在,从而解决了幻读的问题。

所以MySQL当中默认的隔离级别是不可重复读,一般也不会去手动更改。

综上所述基本说清楚了在InnoDB引擎当中所产生的并发事务问题,是如何解决的,以及为什么会有隔离级别这个概念,它们之间有什么区别,作用又是什么,希望本篇文章能够帮助大家更有效地理解这一部分的知识。

MySQL InnooDB引擎之并发事务问题以及隔离级别的作用和区别的更多相关文章

  1. Mysql三种日志(binlog,redolog,undolog)的作用和区别

    Mysql有三种很重要的日志也是面试经常涉及到的考点,分别是 binlog .redo log和undo log, 这里面binlog 是server层实现的日志,而redo log 和undo lo ...

  2. MySQL数据库引擎、事务隔离级别、锁

    MySQL数据库引擎.事务隔离级别.锁 数据库引擎InnoDB和MyISAM有什么区别 大体区别为: MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持.MyISAM类型的表强调的是性能 ...

  3. MySQL存储引擎:InnoDB和MyISAM的差别/优劣评价/评测/性能测试

    InnoDB和MyISAM简介 MyISAM:这个是默认类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的 顺序访问方法) 的缩写 ...

  4. MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述

    MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述: 1.MySQL有多种存储引擎: MyISAM.InnoDB.MERGE.MEMORY(HEAP).BDB(Berk ...

  5. 随着应用对事务完整性和并发性要求的不断提高,MySQL才开始开发基于事务的存储引擎

    MYSQL 解锁与锁表 - 专注it - 博客园 https://www.cnblogs.com/wanghuaijun/p/5949934.html 2016-10-11 16:50 MYSQL 解 ...

  6. MySQL · 引擎特性 · InnoDB 事务子系统介绍

    http://mysql.taobao.org/monthly/2015/12/01/ 前言 在前面几期关于 InnoDB Redo 和 Undo 实现的铺垫后,本节我们从上层的角度来阐述 InnoD ...

  7. MySQL存储引擎,优化,事务

    1唯一约束unique和主键key的区别?     1.什么是数据的存储引擎?       存储引擎就是如何存储数据.如何为存储的数据建立索引和如何更新.查询数据等技术的实现方法.因为在关系数据库中数 ...

  8. MySQL · 引擎特性 · InnoDB 事务系统

    前言 关系型数据库的事务机制因其有原子性,一致性等优秀特性深受开发者喜爱,类似的思想已经被应用到很多其他系统上,例如文件系统等.本文主要介绍InnoDB事务子系统,主要包括,事务的启动,事务的提交,事 ...

  9. MySQL存储引擎与事务

    1.作用 和磁盘的数据打交道 2.简介 MySQL  基于存储引擎管理 表空间数据数据文件 3.种类 Innodb存储引擎ibd:存储表的数据行和索引frm:表基本结构信息Myisam存储引擎frmm ...

  10. Mysql InnoDB引擎下 事务的隔离级别

    mysql InnoDB 引擎下事物学习 建表user CREATE TABLE `user` ( `uid` bigint(20) unsigned NOT NULL AUTO_INCREMENT, ...

随机推荐

  1. 如何通过C#/VB.NET设置Word文档段落缩进

    缩进是指调整文本与页面边界之间的距离.在水平标尺,有四个段落缩进滑块:首行缩进.悬挂缩进.左缩进以及右缩进.在对于word文档的录入时,常常需要注意录入的格式,通过合理地设置段落格式,可以让文稿看起来 ...

  2. 关于 Math.random()生成指定范围内的随机数的公式推导

    关于 Math.random()生成指定范围内的随机数的公式推导 在 java 中,用于生成随机数的 Math 方法 random()只能生成 0-1 之间的随机数,而对于生成指定区间,例如 a-b ...

  3. 可别小看了XSS漏洞

    可别小看了XSS漏洞 ​ 对于初了解xss漏洞的人来说,XSS漏洞的危害就是获取受害者的cookie,来进行 'cookie劫持'. ​ 今天就总结一下XSS漏洞的危害性,望安全人员不要轻视,开发人员 ...

  4. kingbaseES V8R6集群备份恢复案例之---备库作为repo主机执行物理备份

    ​ 案例说明: 此案例是在KingbaseES V8R6集群环境下,当主库磁盘空间不足时,执行sys_rman备份,将集群的备库节点作为repo主机,执行备份,并将备份存储在备库的磁盘空间. 集群架构 ...

  5. Git&GitHub 03 使用 SSH 协议

    注意事项与声明 平台: Windows 10 作者: JamesNULLiu 邮箱: jamesnulliu@outlook.com 博客: https://www.cnblogs.com/james ...

  6. 详解字符编码与 Unicode

    人类交流使用 A.B.C.中 等字符,但计算机只认识 0 和 1.因此,就需要将人类的字符,转换成计算机认识的二进制编码.这个过程就是字符编码. ASCII 最简单.常用的字符编码就是 ASCII(A ...

  7. C# 中的那些锁,在内核态都是怎么保证同步的?

    一:背景 1. 讲故事 其实这个问题是前段时间有位朋友咨询我的,由于问题说的比较泛,不便作答,但想想梳理一下还是能回答一些的,这篇就来聊一聊下面这几个锁. Interlocked AutoResetE ...

  8. linux软链接的创建、修改和删除

    创建 ln -s [源文件或目录] [目标文件或目录] 修改 ln –snf [新的源文件或目录] [目标文件或目录] 删除 rm –rf 软链接名称 注意,上面这种形式可能会让人产生担忧,害怕删除的 ...

  9. PostgreSQL 删除表格

    PostgreSQL 使用 DROP TABLE 语句来删除表格,包含表格数据.规则.触发器等,所以删除表格要慎重,删除后所有信息就消失了. 语法 DROP TABLE 语法格式如下: DROP TA ...

  10. 20. 使用Fluentd发送告警邮件

    告警是预防系统故障的一个重要工具,目前已经有许多成熟的方案通过监控系统运行指标来进行阈值预警.今天简单了解一下如何使用Fluentd实现邮件告警功能. Fluentd的告警是基于日志分析实现的,通过监 ...