看完这篇文章,让你彻底理解事务隔离级别(读未提交、读已提交、可重复读、序列化)

本文主要是介绍看完这篇文章,让你彻底理解事务隔离级别(读未提交、读已提交、可重复读、序列化),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

对于不同的事务,采用不同的隔离级别分别有不同的现象。主要有下面3种:

1、脏读(dirty read):一个事务可以读取另一个尚未提交事务的修改数据。

2、不可重复读(nonrepeatable read)是指在数据库访问中,一个事务范围内两个相同的查询却返回了不同数据。

3、幻像读(phantom read):在同一事务中,同一查询多次进行时候,由于其他插入操作(insert)的事务提交,导致每次返回不同的结果集。

事务的隔离级别:

隔离级别脏读不可重复读幻读含义

read uncommitted(未提交读)

允许你读取别人未提交的事务,会出现脏读、幻读、不可重复读
read committed(读已提交)对事务已经提交的数据进行读取。解决了脏读。会出现幻读和不可重复度
repeatable read(重复读)在一个事务中。对相同字段条件读取数据都是一致的。但此类会出现幻读
serializable(序列化)完全服从数据库的ACID,不会出现幻读、不可重复读、脏读。但开启这类级别会非常消耗性能。它是典型的通过完全锁定在事务中涉及到数据库表的来完成的

其实针对文字性的东西。我们程序员不太好理解。就算理解了,过段时间也就忘了。所以还是要去做实验,让自己清楚。原来在这个场景下。这个概念 是这样的。

那让我们一起开启探索。mysql数据库的各个隔离级别的具体含义

准备两个窗口。一个修改数据的窗口,一个查询数据的窗口

1、read uncommitted 

模拟读未提交

首先设置数据库的隔离级别为读未提交

set  session transaction isolation level  read UNCOMMITTED

用命令 SELECT @@tx_isolation;查询下设置的级别

因为我是用navicat Premium工具连接的数据库。开启两个查询窗口(切记这两个查询窗口都需要设置隔离级别

在修改数据的窗口执行以下操作:

1、开启事务(begin)

2、修改数据disablestate设置为7。这时不要提交事务

3、用另个事务去查询数据,结果disablestate数据为7

果然读取到了,未提交的数据。所以也验证了未提交读。你修改了数据,但是事务还没来及提交。竟然被人家读取了

 2、read committed

按照同样的步骤。把数据库的隔离级别设置为读已提交

 set  session transaction isolation level read committed

 

在修改数据的窗口执行以下操作: 

1、开启事务(begin)

 2、修改数据设置disablestate为8

 update user_account set disablestate='8' where id='3';

此时还未提交事务。去另个窗口去查询下数据读取到的disablestate为7

 用了读已提交,不会读取到未提交的事务的数据。解决了脏读。但是不可重复读这个是什么呢?

看我的sql

 在一个事务中。读取两次。首先修改数据。不提交事务。执行第二行sql。

读取到disablestate为7。在修改的数据的窗口。提交事务,执行第三行sql

哦。数据变了。这就是所谓的不可重复读。在一个事务中。重复读取一条数据。出现了不同的结果 。解决不可重复读。当然用可重复读。

3、repeatable read

按照同样的步骤。把数据库的隔离级别设置为可重读

set  session transaction isolation level  REPEATABLE READ
 

在修改数据的窗口执行以下操作:

1、开启事务

2、修改数据。把disablestate设置为9,先不要提交事务

 在查询窗口中执行

两次查询都是之前的数据8。所以你理解了可重复读了吗?但是这个级别解决不了幻读。你get到了吗?用相同方法去尝试模拟幻读吧

序列化就不做过多演示了。序列化可以解决幻读。但是这个隔离级别性能消耗太大。基本不用 

这篇关于看完这篇文章,让你彻底理解事务隔离级别(读未提交、读已提交、可重复读、序列化)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/320255

相关文章

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

Java整合Protocol Buffers实现高效数据序列化实践

《Java整合ProtocolBuffers实现高效数据序列化实践》ProtocolBuffers是Google开发的一种语言中立、平台中立、可扩展的结构化数据序列化机制,类似于XML但更小、更快... 目录一、Protocol Buffers简介1.1 什么是Protocol Buffers1.2 Pro

深入理解go中interface机制

《深入理解go中interface机制》本文主要介绍了深入理解go中interface机制,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录前言interface使用类型判断总结前言go的interface是一组method的集合,不

Linux中的自定义协议+序列反序列化用法

《Linux中的自定义协议+序列反序列化用法》文章探讨网络程序在应用层的实现,涉及TCP协议的数据传输机制、结构化数据的序列化与反序列化方法,以及通过JSON和自定义协议构建网络计算器的思路,强调分层... 目录一,再次理解协议二,序列化和反序列化三,实现网络计算器3.1 日志文件3.2Socket.hpp

SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南

《SpringBoot集成EasyExcel实现百万级别的数据导入导出实践指南》本文将基于开源项目springboot-easyexcel-batch进行解析与扩展,手把手教大家如何在SpringBo... 目录项目结构概览核心依赖百万级导出实战场景核心代码效果百万级导入实战场景监听器和Service(核心

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

Java Spring的依赖注入理解及@Autowired用法示例详解

《JavaSpring的依赖注入理解及@Autowired用法示例详解》文章介绍了Spring依赖注入(DI)的概念、三种实现方式(构造器、Setter、字段注入),区分了@Autowired(注入... 目录一、什么是依赖注入(DI)?1. 定义2. 举个例子二、依赖注入的几种方式1. 构造器注入(Con