首页 > 编程语言 >高级java每日一道面试题-2024年9月02日-基础篇-什么是脏读、不可重复读和幻读?

高级java每日一道面试题-2024年9月02日-基础篇-什么是脏读、不可重复读和幻读?

时间:2024-09-02 18:22:57浏览次数:15  
标签:02 面试题 java 读取 幻读 事务 Read 脏读 数据

如果有遗漏,评论区告诉我进行补充

面试官: 什么是脏读、不可重复读和幻读?

我回答:

在数据库事务的并发控制中,脏读(Dirty Read)、不可重复读(Non-repeatable Read)和幻读(Phantom Read)是三种常见的并发问题,它们主要涉及到事务的隔离级别和一致性。了解这些问题有助于我们设计更健壮的数据库系统。

1. 脏读(Dirty Read)

  • 定义: 脏读是指一个事务读取到了另一个事务尚未提交的数据。
  • 影响: 如果一个事务读取了另一个未提交事务的数据,然后该事务被回滚,那么第一个事务读取的数据实际上是无效的。这种情况会导致数据的不一致性和不可预测性。脏读违反了数据库的“隔离性”原则。

示例

  • 事务A修改了某行数据,但尚未提交。
  • 事务B读取了事务A修改后的数据。
  • 事务A由于某种原因回滚,撤销了之前的修改。
  • 此时,事务B读取的数据就是“脏”的,因为它读取了从未真正存在的数据。

2. 不可重复读(Non-repeatable Read)

  • 定义: 不可重复读是指一个事务在执行过程中多次读取同一数据时,由于其他事务的并发执行,导致读取结果不一致的现象。
  • 影响: 在同一个事务内,两次或多次查询相同的数据返回了不同的结果。这是因为其他事务在这段时间内对数据进行了修改并提交了这些修改。这通常是因为其他事务修改了数据,但并非所有数据库系统都认为这是问题(取决于其隔离级别)。

示例

  • 事务A两次读取同一数据集合。
  • 在两次读取之间,事务B修改了集合中的某些数据并提交。
  • 因此,事务A的两次读取结果不一致。

3. 幻读(Phantom Read)

  • 定义: 幻读是指一个事务在执行过程中多次读取同一数据集合时,由于其他事务的并发执行,导致数据集合发生变化的现象。
  • 影响: 在同一个事务内,两次或多次查询相同的数据集合返回了不同的结果。这是因为其他事务在这段时间内插入或删除了一些记录。

示例

  • 事务A执行了一个范围查询(如SELECT * FROM table WHERE id > 10)。
  • 在事务A再次执行相同查询之前,事务B插入了新的行(如id = 12)并提交。
  • 当事务A再次执行相同的范围查询时,会发现新的行(id = 12),即出现了“幻读”。

4. 隔离级别

为了解决这些问题,数据库提供了不同的隔离级别,从低到高依次为:

  • 读未提交(Read Uncommitted):允许脏读、不可重复读和幻读。
  • 读已提交(Read Committed):禁止脏读,但允许不可重复读和幻读。
  • 可重复读(Repeatable Read):禁止脏读和不可重复读,但某些数据库(如MySQL的InnoDB引擎)的默认设置可能仍允许幻读。
  • 串行化(Serializable):最高的隔离级别,禁止脏读、不可重复读和幻读。它通过强制事务串行执行来实现,但会影响性能。

理解这些概念对于设计和实现高性能且一致的数据库应用至关重要。在实际开发中,应根据业务需求和性能要求选择合适的事务隔离级别。

标签:02,面试题,java,读取,幻读,事务,Read,脏读,数据
From: https://blog.csdn.net/qq_43071699/article/details/141826173

相关文章

  • 高级java每日一道面试题-2024年9月02日-基础篇-如何处理嵌套事务?
    如果有遗漏,评论区告诉我进行补充面试官:如何处理嵌套事务?我回答:处理嵌套事务(NestedTransactions)是Java开发中一个常见的问题,特别是在涉及多个数据库操作时。嵌套事务指的是在一个事务中又开始了另一个事务,形成了事务的层次结构。处理嵌套事务需要特别注意事务的边界......
  • JAVA List<Map<String, Object>> sort 多个排序写法
     基本方法/***排序=**@paramlist*@paramsort_key*@return*/publicstaticList<Map<String,Object>>sort(List<Map<String,Object>>list,Stringsort_key,Booleanasc,Stringsort_key2,Boole......
  • 面试题
    面试题浏览器是如何渲染页面的?当浏览器的网络线程收到HTML文档后,会产生一个渲染任务,并将其传递给渲染主线程的消息队列。在事件循环机制的作用下,渲染主线程取出消息队列中的渲染任务,开启渲染流程。整个渲染流程分为多个阶段,分别是:HTML解析、样式计算、布局、分层、绘制、......
  • 高密度、高速卡边缘连接器,ME1005610201091、ME1005610203071、ME1005613401311、ME100
    系列概述MiniCoolEdge是一款0.60mm高密度、高速卡边缘连接器,适用于新一代小型系统。这种精细间距解决方案支持多种板对板应用,如直角、夹层/共面,并提供电缆互连选件。这些连接器符合SFF-TA-1002、GenZ、EDSFF和OCPNIC3.0规范。常见应用包括固态驱动器、网络接口卡和......
  • js面试题手写代码
    实现一个new操作符实现一个instacneof操作符 实现一个new操作符 functionmyNew(fn,...args){if(typeoffn!=='function){returnTypeError('fnmustbeafunction')}//letobj={}创建一个空对象//obj.__proto__=fn.prototype将......
  • Java平衡树--查找树的新建与树的实现
    Java学习+面试指南:https://javaxiaobear.cn1、查找树的定义一棵2-3查找树要么为空,要么满足满足下面两个要求:2-结点含有一个键(及其对应的值)和两条链,左链接指向2-3树中的键都小于该结点,右链接指向的2-3树中的键都大于该结点。3-结点含有两个键(及其对应的值)和三条链,左链接指向的2......
  • 【2024-08-30】大宝试学
    20:00存心不善,风水无益;不孝父母,奉神无益;兄弟不和,交友无益;行止不端,读书无益;心高气傲,博学无益;做事乖张,聪明无益;不惜元气,服药无益;时运不通,妄求无益;妄取人财,布施无益;淫恶肆欲,阴骘无益。                              ......
  • Java 最小优先队列API设计与实现
    Java学习+面试指南:https://javaxiaobear.cn最小的元素放在数组的索引1处。每个结点的数据总是小于等于它的两个子结点的数据。1、API设计类名MinPriorityQueue构造方法MinPriorityQueue(intcapacity):创建容量为capacity的MinPriorityQueue对象成员方法privatebooleanless(inti......
  • Java 堆的设计,如何用堆进行排序
    Java学习+面试指南:https://javaxiaobear.cn1、堆的定义堆是计算机科学中一类特殊的数据结构的统称,堆通常可以被看做是一棵完全二叉树的数组对象。1、堆的特性它是完全二叉树,除了树的最后一层结点不需要是满的,其它的每一层从左到右都是满的,如果最后一层结点不是满的,那么要求左满右......
  • Java最大优先队列设计与实现
    Java学习+面试指南:https://javaxiaobear.cn1、API设计类名MaxPriorityQueue构造方法MaxPriorityQueue(intcapacity):创建容量为capacity的MaxPriorityQueue对象成员方法privatebooleanless(inti,intj):判断堆中索引i处的元素是否小于索引j处的元素privatevoideach(inti,int......