mysql-事务隔离级别
事务的隔离级别比我们想象的还要复杂,在sql标准中一共定义了4中隔离级别,每一种都定义了事务所做的的修改,比如哪些事务内和事务间是可见的,哪些是不可以见的。下面是四种事务的隔离级别:
1、读未提交(Read UnCommited)
在此事务内已经修改了数据,但是没有提交事务,对其他事务都是可见的,其他事务可以读取到刚才那个修改数据没有提交的事务。我们称为这种为 “脏读”。这种可能导致很多问题出现,在一般的实际应用中很少使用。
2、读已提交(Read Commited)
这个事务隔离级别是大多数数据库默认采用的事务隔离级别,但是mysql没有默认采用,在一个修改的事务,还没有提交事务,对于其他事务内的操作都是不可见的。也就是一个事务只能看到已经提交事务的数据。这种我们称为“不可重复读”,因为2此读取的时候可能得到不同的结果。
3、可重复读(Repeatable Read)
可重复读解决了脏读的问题,该隔离级别保证在一个事务里读取的数据记录是一致的,但是理论上又会出现幻读的问题发生,比如我们在读取某个访问记录,另外一个事务正好插入数据了。之前的那个事务再次读取会产生幻行。值得庆幸的是mysql采用的Innodb 和XtraDB存储引擎通过多版本进行并发控制的,来解决这个幻读问题。
4 可串行化(Serializable)
强制事务进行串行化执行,读取的每一行都加锁,避免幻读现象产生可能导致锁的争夺和超时消耗,是事务隔离级别最大的一个,一般在实际的项目中很少用到。
多版本并发控制
mysql 的大多数数据库事务存储引擎大多不是简单的行级锁,基于提高并发性考虑,一般采用多版本控制实现,不仅仅是mysql ,oracle也是如此,可以认为多版本并发控制是行级别锁的变种,大多情况下避免了加锁的操作,因此开销更低,大部分实现非阻塞的读操作,和写操作也只锁定必要的行。多版本并发控制通过保存数据在某个时间点的快照来实现的,也就是说,不管执行多长时间,每个事务看到的数据是一致的,根据事务的开始时间不同,每个事务对应同一张表,同一时刻可能看到的数据不一样。实现版本并发控制包括乐观并发控制和悲观并发控制。
InnoDB存储引擎是通过每一行记录后面保存两个隐藏的列来实现的,默认采用可重复读隔离级别。这两列,一列保存行的创建时间,另外一列保存行的过期时间,时间不是系统时间 而是系统版本号,每当开始一个事务系统版本号就会开始递增,事务开始的时刻的系统版本号作为事务的版本号,与用来查询到的每行记录的版本号进行做对比,在可重复读的隔离级别的下版本并发控制解决幻读的问题:
SELECT(查询)
innodb 会根据只查询早于当前事务查询的版本号的数据行并且行的过期时间(删除版本号)要么未定义要么大于当前版本号才能返回查询结果。
INSERT(插入)
InnoDB为新插入的每一行记录保存当前系统版本号作为行版本号
UPDATE(更新)
InnoDB为插入一行新记录,保存当前版本号作为开始时间的版本号,同时,保存当前版本号到原来行的结束列作为行删除标识。
DELETE (删除)
Innodb 为每一行要删除的行,保存当前版本号作为行删除标识。
总结
InnoDB存储引擎使每一行记录保存额外的两个系统版本号列,使大多读操作都可以不加锁,这样设计使读操作非常简单,性能很好防止了幻读的情况发生,但是每一行要维护2列系统版本号需要额外的空间,并且也要进行检查工作及一些维护的操作。
相关推荐
基于微信小程序的在线办公小程序答辩PPT.pptx
这个数据集来自世界卫生组织(WHO),包含了2000年至2015年期间193个国家的预期寿命和相关健康因素的数据。它提供了一个全面的视角,用于分析影响全球人口预期寿命的多种因素。数据集涵盖了从婴儿死亡率、GDP、BMI到免疫接种覆盖率等多个维度,为研究者提供了丰富的信息来探索和预测预期寿命。 该数据集的特点在于其跨国家的比较性,使得研究者能够识别出不同国家之间预期寿命的差异,并分析这些差异背后的原因。数据集包含22个特征列和2938行数据,涉及的变量被分为几个大类:免疫相关因素、死亡因素、经济因素和社会因素。这些数据不仅有助于了解全球健康趋势,还可以辅助制定公共卫生政策和社会福利计划。 数据集的处理包括对缺失值的处理、数据类型转换以及去重等步骤,以确保数据的准确性和可靠性。研究者可以使用这个数据集来探索如教育、健康习惯、生活方式等因素如何影响人们的寿命,以及不同国家的经济发展水平如何与预期寿命相关联。此外,数据集还可以用于预测模型的构建,通过回归分析等统计方法来预测预期寿命。 总的来说,这个数据集是研究全球健康和预期寿命变化的宝贵资源,它不仅提供了历史数据,还为未来的研究和政策制
基于微信小程序的“健康早知道”微信小程序答辩PPT.pptx
基于微信小程序的电影交流平台答辩PPT.pptx
计算机字符编码GB18030
Hive 操作基础(进阶版)多级分区数据文件2
基于java的贫困生管理系统答辩PPT.pptx
pandas whl安装包,对应各个python版本和系统(具体看资源名字),找准自己对应的下载即可! 下载后解压出来是已.whl为后缀的安装包,进入终端,直接pip install pandas-xxx.whl即可,非常方便。 再也不用担心pip联网下载网络超时,各种安装不成功的问题。
TA_lib库(whl轮子),直接pip install安装即可,下载即用,非常方便,各个python版本对应的都有。 使用方法: 1、下载下来解压; 2、确保有python环境,命令行进入终端,cd到whl存放的目录,直接输入pip install TA_lib-xxxx.whl就可以安装,等待安装成功,即可使用! 优点:无需C++环境编译,下载即用,方便
本压缩包资源说明,你现在往下拉可以看到压缩包内容目录 我是批量上传的基于SpringBoot+Vue的项目,所以描述都一样;有源码有数据库脚本,系统都是测试过可运行的,看文件名即可区分项目~ |Java|SpringBoot|Vue|前后端分离| 开发语言:Java 框架:SpringBoot,Vue JDK版本:JDK1.8 数据库:MySQL 5.7+(推荐5.7,8.0也可以) 数据库工具:Navicat 开发软件: idea/eclipse(推荐idea) Maven包:Maven3.3.9+ 系统环境:Windows/Mac
tornado-6.2b2.tar.gz
javawe论坛项目 原生技术
tornado-6.2b1-cp310-cp310-macosx_10_9_universal2.whl
随着物流行业的快速发展,货运管理变得愈发重要。为了提高货运效率,确保货物安全,我们开发了这款基于司机信用评价的货运管理系统。 该系统主要包含了货物信息管理、订单评价管理、货主管理等多个功能模块。在货物信息管理模块中,用户可以查看和管理货物的详细信息,包括货物名称、规格、装车状态、运输状态以及卸货状态等,方便用户随时掌握货物的动态。 订单评价管理模块是该系统的核心之一,它允许货主对司机的服务进行评价,系统会根据评价数据对司机进行信用评分。这一功能不仅有助于提升司机的服务质量,还能为货主提供更加可靠的货运选择。 此外,货主管理模块提供了货主信息的录入、修改和查询等功能,方便用户管理自己的货主资料。系统界面简洁明了,以蓝色为主色调,设计现代且专业,为用户提供了良好的使用体验。 通过该系统,用户可以轻松实现货物信息的查看和管理,对司机的服务进行评价,提高货运效率和服务质量。同时,系统也为司机提供了一个展示自我、提升信用的平台,有助于推动物流行业的健康发展。
毕业生交流学习平台 SSM毕业设计 附带论文 启动教程:https://www.bilibili.com/video/BV1GK1iYyE2B
基于java的广场舞团答辩PPT.pptx
基于java的基于SSM的校园音乐平台答辩PPT.pptx
Jira插件安装包
项目经过测试均可完美运行! 环境说明: 开发语言:java jdk:jdk1.8 数据库:mysql 5.7+ 数据库工具:Navicat11+ 管理工具:maven 开发工具:idea/eclipse
tornado-6.2b2-cp37-abi3-win_amd64.whl