【MySQL】脏读,幻读,不可重复读

2024-04-22 09:44

本文主要是介绍【MySQL】脏读,幻读,不可重复读,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

脏读、幻读、不可重复读

一、脏读

二、幻读

三、不可重复读

四、脏读、幻读、不可重复读的区别


一、脏读

脏读主要发生在隔离级别很低的事务之间,就比如隔离级别设为Read Uncommitted,也就是读为提交。当我们有多个数据库并发的访问一张表的时候,就会发生脏读。

那么到底什么是脏读?

脏读就是假如,我有两个数据库并发的访问一张表,我的隔离级别是读未提交的,也就是Read Uncommitted,这种隔离级别下,我只要发生数据的更新,另一个并发访问的数据库也就会立马看到结果,这样会发生脏读的情况。就比如,有个学生要转专业,那么我的一个数据库就对这个表的该学生的专业信息进行修改,然后并发访问的另一个数据库就去读数据,发现这个学生的专业已经被修改好了,它就可能下线了,但是由于种种原因,第一个数据库在运行的过程中崩溃了,事务还没有提交,这时候就会发生回滚,该学生的专业的数据又回滚成原专业,但是另一个数据库不知道我发生回滚了,它就认为,这个学生的专业信息已经更改成功了!这样子就产生了脏读的情况,这种影响是十分可怕的!

二、幻读

幻读是也是发生在并发访问同一张表的时候,我第一次查表中的数据,比如我要查公司员工年龄小于30岁的员工有哪些,这时候我的第一个数据库就去查,然后第一次查完之后,并发访问的那个数据库的管理者接到人事通知,有个应届生入职我们公司了,录入一下他的个人信息,然后我就录入了这个员工的个人信息,而这时候,我的第一个数据库觉得,要多查几次,保证我有没有漏掉哪些信息,然后我就去查,发现!怎么又多了一行,我是不是产生幻觉了,刚刚好像没有这一行。

这就是幻读带来的影响,会使得数据库的使用者对数据失去信任感,也造成数据不一致的问题出现。

三、不可重复读

不可重复读通常发生在读提交的隔离级别之下,也就是Read Committed,也就是别人提交了事务,我这边才能看到结果,

就比如:我要查一个员工薪资情况,两个数据库并发访问,第一个数据库对表的数据查询,在第二次查询之前,我的第二个数据库对这名员工的薪资上调,然后提交了事务,第一个数据库现在对表进行第二次查询,发现这个员工的薪资和第一个查到的结果不一样,这就是不可重复读。


四、脏读、幻读、不可重复读的区别

首先这三者都是由于并发访问引起的问题,但是

  • 脏读是发生在两个事务之间,由一个事务更改,另一个事务读取,前一个事务发生回滚操作,后一个事务读到的结果不一致的问题
  • 幻读是发生在同一个事务内部,通常发生在两次查询操作的中间,另一个数据库对表进行了删除列,插入新的元素,增加列,导致第二次查询的时候,发现和第一次查询结果少了或者多了某些列或者行,就好像产生了幻觉一样。
  • 不可重复读也是发生在同一个事务内部,也是发生在二次查询的中间对表进行了操作,他和幻读不一样的点在于,幻读是查的时候多了或者少了某些列,它是发现表中的某些数据和前一次查询的结果不一样的问题。

这篇关于【MySQL】脏读,幻读,不可重复读的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL双主搭建+keepalived高可用的实现

《MySQL双主搭建+keepalived高可用的实现》本文主要介绍了MySQL双主搭建+keepalived高可用的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、测试环境准备二、主从搭建1.创建复制用户2.创建复制关系3.开启复制,确认复制是否成功4.同

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

MySQL错误代码2058和2059的解决办法

《MySQL错误代码2058和2059的解决办法》:本文主要介绍MySQL错误代码2058和2059的解决办法,2058和2059的错误码核心都是你用的客户端工具和mysql版本的密码插件不匹配,... 目录1. 前置理解2.报错现象3.解决办法(敲重点!!!)1. php前置理解2058和2059的错误

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

MySQL INSERT语句实现当记录不存在时插入的几种方法

《MySQLINSERT语句实现当记录不存在时插入的几种方法》MySQL的INSERT语句是用于向数据库表中插入新记录的关键命令,下面:本文主要介绍MySQLINSERT语句实现当记录不存在时... 目录使用 INSERT IGNORE使用 ON DUPLICATE KEY UPDATE使用 REPLACE

MySQL Workbench 安装教程(保姆级)

《MySQLWorkbench安装教程(保姆级)》MySQLWorkbench是一款强大的数据库设计和管理工具,本文主要介绍了MySQLWorkbench安装教程,文中通过图文介绍的非常详细,对大... 目录前言:详细步骤:一、检查安装的数据库版本二、在官网下载对应的mysql Workbench版本,要是

mysql数据库重置表主键id的实现

《mysql数据库重置表主键id的实现》在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,本文主要介绍了mysql数据库重置表主键id的实现,具有一定的参考价值,感兴趣的可以了... 目录关键语法演示案例在我们的开发过程中,难免在做测试的时候会生成一些杂乱无章的SQL主键数据,当我们