数据库事务隔离级别

数据库事务的隔离级别有4个,由低到高依次为Read uncommittedRead committedRepeatable readSerializable,这四个级别可以逐个解决脏读不可重复读幻读这几类问题。


√: 可能出现    ×: 不会出现

脏读不可重复读幻读
Read uncommitted
Read committed×
Repeatable read××
Serializable×××

 

注意:我们讨论隔离级别的场景,主要是在多个事务并发的情况下,因此,接下来的讲解都围绕事务并发。

Read uncommitted 读未提交

公司发工资了,领导把5000元打到singo的账号上,但是该事务并未提交,而singo正好去查看账户,发现工资已经到账,是5000元整,非常高兴。可是不幸的是,领导发现发给singo的工资金额不对,是2000元,于是迅速回滚了事务,修改金额后,将事务提交,最后singo实际的工资只有2000元,singo空欢喜一场。


 

出现上述情况,即我们所说的脏读,两个并发的事务,“事务A:领导给singo发工资”、“事务B:singo查询工资账户”,事务B读取了事务A尚未提交的数据。

当隔离级别设置为Read uncommitted时,就可能出现脏读,如何避免脏读,请看下一个隔离级别。

Read committed 读提交

singo拿着工资卡去消费,系统读取到卡里确实有2000元,而此时她的老婆也正好在网上转账,把singo工资卡的2000元转到另一账户,并在singo之前提交了事务,当singo扣款时,系统检查到singo的工资卡已经没有钱,扣款失败,singo十分纳闷,明明卡里有钱,为何......

出现上述情况,即我们所说的不可重复读,两个并发的事务,“事务A:singo消费”、“事务B:singo的老婆网上转账”,事务A事先读取了数据,事务B紧接了更新了数据,并提交了事务,而事务A再次读取该数据时,数据已经发生了改变。

当隔离级别设置为Read committed时,避免了脏读,但是可能会造成不可重复读。

大多数数据库的默认级别就是Read committed,比如Sql Server , Oracle。如何解决不可重复读这一问题,请看下一个隔离级别。

Repeatable read 重复读

当隔离级别设置为Repeatable read时,可以避免不可重复读。当singo拿着工资卡去消费时,一旦系统开始读取工资卡信息(即事务开始),singo的老婆就不可能对该记录进行修改,也就是singo的老婆不能在此时转账。

虽然Repeatable read避免了不可重复读,但还有可能出现幻读

singo的老婆工作在银行部门,她时常通过银行内部系统查看singo的信用卡消费记录。有一天,她正在查询到singo当月信用卡的总消费金额(select sum(amount) from transaction where month = 本月)为80元,而singo此时正好在外面胡吃海塞后在收银台买单,消费1000元,即新增了一条1000元的消费记录(insert transaction ... ),并提交了事务,随后singo的老婆将singo当月信用卡消费的明细打印到A4纸上,却发现消费总额为1080元,singo的老婆很诧异,以为出现了幻觉,幻读就这样产生了。

注:MySQL的默认隔离级别就是Repeatable read。

Serializable 序列化

Serializable是最高的事务隔离级别,同时代价也花费最高,性能很低,一般很少使用,在该级别下,事务顺序执行,不仅可以避免脏读、不可重复读,还避免了幻像读。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/553742.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

爱奇艺视频有哪些插件?爱奇艺插件怎么卸载

是不是觉得爱奇艺视频占空间大,但是又不想卸载?是不是觉得爱奇艺有很多插件,那么怎么卸载爱奇艺插件呢?流星告诉你: 1、首先打开手机爱奇艺视频,然后在通知栏下方找到【我的】按钮,如图所示: 爱奇艺201…

腾讯视频如何设置定时关机

腾讯视频如何设置定时关机?下面详细介绍操作步骤: 腾讯视频app官方下载_腾讯视频如何设置定时关机 1、打开电脑,进入腾讯视频主屏幕,点击右边的菜单图标。 腾讯视频app官方下载_腾讯视频如何设置定时关机 2、点击下拉菜单的设置。 腾讯…

dataTable删除行

思路大概就是:通过data()循环匹配,返回当前index,然后通过row(index).remove()删除 var removeIndex;//待删除行index var table $("#tb").DataTable(); var datas table.data(); $.each(datas,function(i,d) {if (d[0] data.id) …

centos6.5配置Hadoop环境,运行wordcount例子

安装vmware12,centos6.5(还是6.5好,稳定流畅,7界面好看但是虚拟机里面卡死了),删除自带openjdk下载安装jdk1.7配置环境变量 vim /etc/profile->最后加上下面这段 export JAVA_HOME/usr/java/jdk1.7.0_79…

Maven打包自动发布到nexus私服

通过命令 -f指定的pom文件 deploy打包发布 Intellij Idea中可以通过Run-EditConfigurations-""号-Maven新建一个自定义maven脚本,将刚才的发布命令填入Command line中保存即可 先设置pom文件里的build信息,可以是maven-compiler-plugin插件 ma…

搜狗浏览器热搜怎么关 热搜关闭方法详解

要说“搜狗浏览器”中最让人不满的地方,相信不少网友都会投该浏览器页面最下面的“搜狗搜索热搜”一票,毕竟其中经常出现一些用户曾经搜索过的或相关的词语!那么,搜狗浏览器中的热搜该怎么关闭呢?让我们通过下文一起来了解一下。 方法步骤 …

分布式服务框架Dubbo使用小结

介绍: Dubbo是一个被国内很多互联网公司广泛使用的开源分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,以及SOA 服务治理方案,每天为2,000个服务提供3,000,000,000次访问量支持,并被广泛应用于阿里巴巴…

Chrome浏览器图片不显示怎么样办 解决方法分享

图片无法正常显示的情况,相信不少经常上网的朋友都曾遇到过。值得一提的是,这种情况大部分都与浏览器本身的缓存文件过多有关!那么,该怎么解决这一问题呢?下面小编就以“Chrome浏览器图片”为例,介绍一下具体的解决方法。 方法步…

AngularJS小结

前段时间做AngularJS的经验总结,这里和大家分享一下: 使用AngularJS的目的是构建一个单页应用,一直是局部刷新,可以达到类似客户端的效果 指令主要参数: restrict : E(元素),A(属性),C(类名),M(注释),默认为…

如何管理QQ浏览器的扩展工具 QQ浏览器扩展工具的管理方法

QQ的庞大安装量带动了腾讯系的所有产品的安装量,QQ浏览器作为腾讯旗下开发的浏览工具,也拥有不俗的装机量。QQ浏览器不仅是沾了QQ的光,其自身实力也有不俗的,QQ浏览器的应用中心与其他浏览器的扩展中心一般支持用户安装各种浏览器…

Java线程池ThreadPoolExecutor的实例

Java.util中的线程池和Spring框架对这个类的扩展 1.单独通过java里的ThreadPoolExecutor这个类,可以创建线程池,如果系统采用Spring框架设计,可以采用ThreadPoolTaskExecutor这个类来扩展控制,这个对维护线程池 最大值和最小值易扩…

win7系统电脑语言栏怎么更换输入法

我们在使用win7操作系统电脑的时候,有些情况下我们可能会想要更换自己的输入法,但是还是有很多小伙伴不知道应该怎么操作。那么对于这个问题小编觉得我们可以通过电脑键盘上面的快捷键来进行操作,也可以使用鼠标在任务栏唤出相关的设置选项即…

记一次生成唯一ID的问题

之前一直用new Date().getTime()作为ID一直没出现啥问题,但是在测试环境被测试人员发现问题了,最终定位到是一个循环体中多次循环所取到的ID竟然是一样的!也就是说系统在1ms之内做了好几次sql操作!好吧,万万没想到。。…

2345浏览器如何启用过滤弹窗广告

2345浏览器是一款非常便捷的浏览服务软件,有很多用户都会使用手机浏览更多的信息,随时都可以享受便捷的服务,使用过的用户都会知道,浏览器的资讯会有广告,其实在看视频的时候也会有广告,那么要怎么过滤弹窗…

Jersey中ContainerRequestFilter的使用

手头上有对所有请求做权限认证的需求,必须要在执行rest方法之前判断用户是否是登录状态,也就是要判断session存不存在,这里使用ContainerRequestFilter,从名字上也能看出来它是一个过滤器,会将所有请求拦截下来&#x…

手机腾讯视频软件如何开启护眼功能

今天给大家简单介绍一下,在手机腾讯视频中,如何开启护眼功能,具体步骤如下: 1、首先,打开手机苏宁易购app; 手机腾讯视频软件如何开启护眼功能 2、进入软件时先点击【跳过】广告页面,如图 手机腾讯视频…

XML解析-Dom4j的DOM解析方式更新XML

Dom4j工具,是非官方的,不在jdk中。 使用步骤: 1)导入dom4j的核心包。 dom4j-1.6.1.jar 2)编写Dom4j读取xml文件的代码 1、更新XML 1.1、写出内容到xml文档 package com.rk.xml.g_dom4j_write;import java.io.File; import java.io…

爱奇艺如何设置最小化显示在托盘

相信很多朋友都有在使用爱奇艺,那么大家对食物爱奇艺的过程当中如何设置最小化显示在托盘呢?关于这个问题小编就和大家分享一下我的经验,希望能够帮助到大家。 爱奇艺会员活动2020_爱奇艺如何设置最小化显示在托盘 1、首先点击电脑桌面中的爱奇艺&…

傲游浏览器怎么看网页源代码 网页源代码查看方法简述

网页源代码,顾名思义就是指在网页制作过程中需要用到的一些特殊的“语言”,设计人员向通过对这些“语言”进行组织编排制作出网页,再由浏览器进行“翻译”后才会出现用户最终看到的效果。那么,在傲游浏览器中该怎么看网页源代码呢…

Qt前端技术:5.QSS

这个是表示QFrame中的pushButton中的子类和它子类的子类都将背景变为red 写成大于的时候表示只有直接的子类对象才会变 这个图中的QGroupBox和QPushButton都是QFrame的直接的子类 这个中的QGroupBox是QFrame的直接的子类但是QPushButton 是QGroupBox的子类,QPushB…