当前位置: 首页 > news >正文

MySQL面试题-事务篇

1.事务的特性(ACID)

事务(Transaction)是指一组操作被看作是一个不可分割的工作单元,这组操作要么全部执行成功,要么全部执行失败。事务的特性通常用 ACID 四个单词来描述,它们分别代表原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)。

  • 原子性:事务是一个原子操作,它要么全部完成,要么全部不完成,不会出现部分完成的情况。如果在事务执行过程中出现了错误,所有的修改将会被回滚(Rollback)到事务开始前的状态,不会对数据产生影响。
  • 一致性:在事务开始和结束时,数据库都必须保持一致性状态。事务开始前和结束后,数据库的完整性约束没有被破坏,所有的数据都应该合法。
  • 隔离性:多个事务之间的操作是相互隔离的,每个事务都感觉不到其他事务的存在。隔离级别可以通过设置来控制事务的隔离程度,例如读未提交、读已提交、可重复读和串行化等级别。
  • 持久性:事务完成后,对于数据的修改应该永久保存在数据库中,即使系统故障或者断电等异常情况也不应该丢失。

2.事务的隔离级别

事务隔离级别是指多个事务之间的隔离程度,它决定了一个事务在修改数据时对其他事务的影响以及读取数据时能够看到其他事务的哪些修改。

MySQL 支持四种标准的隔离级别,分别是:

  1. 读未提交(Read Uncommitted):允许脏读,一个事务可以读取到另一个未提交的事务修改的数据,会出现幻读、不可重复读和脏读等问题。

  2. 读提交(Read Committed):只能读取到已经提交的数据,但是在同一个事务中,多次读取同一数据,可能会得到不同的结果,也会出现幻读问题。

  3. 可重复读(Repeatable Read):保证了同一个事务中多次读取同一数据结果相同,但是在事务执行过程中,会出现新插入的数据无法读取到的问题,即幻读问题。

  4. 串行化(Serializable):强制事务串行执行,避免了脏读、不可重复读和幻读问题,但是会大大降低数据库的并发性能。

在实际应用中,应根据业务的特点和数据的一致性需求选择合适的隔离级别。一般情况下,推荐使用可重复读隔离级别。

隔离级别脏读不可重复读幻读
READ-UNCOMMITTED
READ-COMMITTED×
REPEATABLE-READ××
SERIALIZABLE×××

3.一致性视图(read-view)

InnoDB通过构造一致性视图来实现RC和RR隔离级别。在RC和RR隔离级别下,事务只能看到在启动该事务时已经提交的数据,也就是说只能看到在该事务启动瞬间,对事务的隔离级别所允许的操作已经完成的数据。为了实现这一点,InnoDB使用了一致性视图机制,通过保存当前活跃事务的ID和启动瞬间已提交的事务ID构建一致性视图,然后在查询时使用该视图来确定可见的数据版本。因此,使用一致性视图机制,InnoDB可以提供高效的RC和RR隔离级别实现。

4.事务隔离是如何实现的 ?

在MySQL中,实际上每条记录在更新的时候都会同时记录一条回滚操作。记录上的最新值,通过回滚操作,都可以得到前一个状态的值。同一条记录在系统中可以存在多个版本,这就是数据库的多版本并发控制(MVCC)。

5.回滚日志什么时候会被删除?

系统会判断当没有事务需要用到这些回滚日志的时候,回滚日志会被删除。

具体来说,当一个事务提交时,如果当前系统中没有其他事务需要使用该事务的回滚日志,则该事务的回滚日志就可以被删除。如果还有其他事务需要使用该事务的回滚日志,则该回滚日志会被保留,直到所有依赖该回滚日志的事务都提交或者回滚。

6.为什么尽量不要使用长事务?

长事务在数据库中长时间占用锁资源,会导致锁等待和死锁等问题,影响系统的并发性能和稳定性。

具体来说,长事务会对回滚日志和MVCC机制造成影响。在数据库中,每个事务都有一个唯一的事务 ID,每次更新操作都会在回滚日志中记录一条对应的回滚操作,用于在事务回滚时恢复数据的一致性。而长事务会使得回滚日志中的回滚操作不断累积,占用大量磁盘空间。同时,长事务中的事务视图也会一直存在,这会使得数据库中的版本链表越来越长,导致查询时的性能下降。

另外,长事务还会增加数据库的故障恢复成本。当数据库出现故障需要恢复时,如果存在长事务,那么需要将这些长事务中所有的操作都回滚,这会导致恢复时间变长。

因此,尽量不要使用长事务,可以将事务尽早提交或者分成多个较短的事务来完成操作。

7.事务是如何实现的MVCC呢? 

事务的实现基于多版本并发控制(MVCC)的机制。在 InnoDB 存储引擎中,每个行都有一个隐藏的字段,用于存储行的创建时间和删除时间,这个字段的名称是 transaction_id。当行被更新或删除时,事务会将一个新的版本写入磁盘,但原来的版本并不会被删除,而是标记为已删除,同时为这个新版本分配一个新的 transaction_id。

在事务开始之前,会为该事务分配一个唯一的事务 ID(transaction_id),同时会记录一个 up_limit_id,表示在当前事务开始之前,已经提交的最大事务 ID。在快照读中,事务会创建一个视图,用于保存当前事务在执行快照读时数据库的状态,这个视图也称为一致性视图(consistent read view)。这个视图是根据当前事务的 transaction_id 和 up_limit_id 计算出来的,它定义了当前事务能够看到哪些行的版本。

在执行快照读时,如果行的 transaction_id 小于等于当前事务的 up_limit_id,那么这行的版本是可见的。否则,这行的版本是不可见的。通过这种机制,InnoDB 实现了快照读。

在当前读中,事务会获取一个共享锁或排它锁来锁定要修改的行,这样其他事务就不能同时修改这行。在当前读时,如果一个行的 transaction_id 大于当前事务的 up_limit_id,那么该行的最新版本需要被读取并加锁,以保证在这个事务内看到的是最新的版本。为了避免幻读,InnoDB 使用了间隙锁(gap lock)来锁定一定范围内的行,从而保证事务内看到的是连续的一段数据。

总之,事务在 InnoDB 中实现了多版本并发控制(MVCC)的机制,通过记录每个行的创建时间和删除时间,以及每个事务的 transaction_id 和 up_limit_id 来实现快照读和当前读。

8.什么是快照读和当前读

快照读(Snapshot Read)是指在读取数据的过程中,不会对数据的修改产生干扰。通常使用MVCC(多版本并发控制)来实现,即读取数据库中某一时刻的快照,而不受其他并发事务的影响。

在InnoDB中,快照读通常使用SELECT语句进行,其实现方式是通过在一致性视图(Consistent Read View)中找到符合条件的数据行版本。而一致性视图是事务启动时创建的,包含了所有已提交的事务和未提交的当前事务。在快照读期间,如果其他事务对数据行进行了修改,那么读取的数据行版本将不会受到影响。

当前读(Current Read)是指在读取数据的过程中,同时对数据进行修改,也就是读取并锁定了数据行,确保其他并发事务无法修改该数据行。当前读通常使用SELECT...FOR UPDATE或SELECT...FOR SHARE语句进行,其中SELECT...FOR UPDATE会对选中的数据行进行加锁,SELECT...FOR SHARE则会对选中的数据行进行共享锁。

当前读与快照读的区别在于当前读会锁定数据行,因此可能会阻塞其他并发事务,而快照读则不会锁定数据行,不会产生阻塞。选择使用哪种读取方式应该根据实际业务需求和数据访问模式来决定。

9.为什么rr能实现可重复读而rc不能

分两种情况

(1)快照读的情况下,rr不能更新事务内的up_limit_id,
而rc每次会把up_limit_id更新为快照读之前最新已提交事务的transaction id,则rc不能可重复读
(2)当前读的情况下,就是读的时候加锁,保证是最新版本,rr是利用record lock+gap lock来实现的,而rc没有gap,所以rc不能可重复读 

相关文章:

MySQL面试题-事务篇

1.事务的特性(ACID) 事务(Transaction)是指一组操作被看作是一个不可分割的工作单元,这组操作要么全部执行成功,要么全部执行失败。事务的特性通常用 ACID 四个单词来描述,它们分别代表原子性&…...

Linux嵌入式开发 | 汇编驱动LED(1)

文章目录🚗 🚗Linux嵌入式开发 | 汇编驱动LED(1)🚗 🚗初始化IO🚗 🚗STM32🚗 🚗使能GPIO时钟🚗 🚗设置IO复用🚗 &#x1f6…...

什么是EventLoop?怎么测试Node或页面的性能

Event Loop 机制大家应该都有了解。本文利用 EventLoop 去做一个有趣的检测node或页面性能的代码,顺便介绍了一下EventLoop,希望对大家有所帮助! Event Loop Event Loop 机制大家应该都有了解。我先重复总结一下。 Node.js 和 Javascript 的…...

1018 锤子剪刀布 1025 反转链表

现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。 输入格式: 输入第 1 行给出正整数 N(≤10 5 ),即双方交锋的次数。随后 N 行,每行给出一次交锋的信…...

卷积神经网络的原理及实现

专栏:神经网络复现目录 卷积神经网络 本章介绍的卷积神经网络(convolutional neural network,CNN)是一类强大的、为处理图像数据而设计的神经网络。 基于卷积神经网络架构的模型在计算机视觉领域中已经占主导地位,当今…...

【C++知识点】重载

✍个人博客:https://blog.csdn.net/Newin2020?spm1011.2415.3001.5343 📚专栏地址:C/C知识点 📣专栏定位:整理一下 C 相关的知识点,供大家学习参考~ ❤️如果有收获的话,欢迎点赞👍…...

apscheduler三种定时触发方式

#第一种# date: 特定的时间点触发# 2019-01-01 00:00:00 准时执行# import time # from apscheduler.schedulers.blocking import BlockingScheduler # # def my_job(): # print(time.strftime(%Y-%m-%d %H:%M:%S, time.localtime(time.time()))) # sched BlockingSchedu…...

802.11 service服务类型

802.11 serviceservice定义service分类按照模块分为两类按照功能分为六类数据传输相关服务分布式服务DS(Distribution Service)整合服务IS(Integration Service)关联(association)重关联(reasso…...

pytest测试框架——allure报告

文章目录一、allure的介绍二、allure的运行方式三、allure报告的生成方式一、在线报告、会直接打开默认浏览器展示当前报告方式二、静态资源文件报告(带index.html、css、js等文件),需要将报告布置到web服务器上。四、allure中装饰器1、实现给…...

SQLI-Labs(3)8-14关【布尔盲注和时间盲注】

目录 第八关 第九关: 第十关 第十一关 第十二关 第十三关 第十四关 第八关 我们用测试语句来测试是否为注入点 从上图中得知存在注入点,那么接下来就是爆列 一共有三列,接下来用union select 和报错注入都试一下发现没有回显点&…...

ESP32学习笔记03-日志打印

ESP32日志 日志分为5个等级 ESP_LOGE - error (lowest)ESP_LOGW - warningESP_LOGI - infoESP_LOGD - debugESP_LOGV - verbose (highest)API 0.头文件 #include "esp_log.h"1.给一个日志标签设置等级...

mongoTemplate非string类型模糊查询

需求 为方便使用人员对任务Task的搜索,需要根据number实现模糊搜索。 背景 之前设计的number是long类型,但是mongodb只支持string类型的正则匹配。 方案 修改number为string类型;新增一个冗余字段,用于模糊查询;在…...

Redis是单线程还是多线程?Redis的10种数据类型,有哪些应用场景?

目录专栏导读一、同样是缓存,用map不行吗?二、Redis为什么是单线程的?三、Redis真的是单线程的吗?四、Redis优缺点1、优点2、缺点五、Redis常见业务场景六、Redis常见数据类型1、String2、List3、Hash4、Set5、Zset6、BitMap7、Bi…...

到底什么才是幻读?

💗推荐阅读文章💗 🌸JavaSE系列🌸👉1️⃣《JavaSE系列教程》🌺MySQL系列🌺👉2️⃣《MySQL系列教程》🍀JavaWeb系列🍀👉3️⃣《JavaWeb系列教程》…...

RPC重试机制和控制方案

重试机制 因为网络抖动等原因导致 RPC 调用失败,这时候使用重试机制可以提高请求的最终成功率,减少故障影响,让系统运行更稳定。 重试简易实现方案 在重试的过程中,为了能够在约定的时间内进行安全可靠地重试,在每次…...

【无标题】动态给结构体赋值

#include <stdio.h> #include <stdlib.h> #include <string.h> typedef struct { int id; char name[20]; double score; } Student; int main() { Student *p (Student *)malloc(sizeof(Student)); if (p NULL) { printf(“Memory allocation failed.”…...

centos7 soft raid每周自动同步的问题

之前redhat老版本时也遇到过这样的问题https://blog.csdn.net/jolly10/article/details/108768360centos7解决的办法略有不同&#xff0c;记录一下&#xff1a;centos7默认是每周日凌晨1点进行raid检查&#xff0c;有点太频繁了[oracleqht117 data]$ ls /etc/cron*/etc/cron.de…...

嵌入式Linux内核代码风格

这是一个简短的文档&#xff0c;描述了linux内核的首选代码风格。代码风格是因人而异的&#xff0c;而且我 不愿意把我的观点强加给任何人&#xff0c;不过这里所讲述的是我必须要维护的代码所遵守的风格&#xff0c; 并且我也希望绝大多数其他代码也能遵守这个风格。请在写代码…...

Andorid:关于Binder几个面试问题

1.简单介绍下binderbinder是一种进程间通讯的机制进程间通讯需要了解用户空间和内核空间每个进程拥有自己的独立虚拟机&#xff0c;系统为他们分配的地址空间都是互相隔离的。如两个进程需要进行通讯&#xff0c;则需要使用到内核空间做载体&#xff0c;内核空间是所有进程共享…...

【剑指Offer-Java】包含min函数的栈?

题目 定义栈的数据结构&#xff0c;请在该类型中实现一个能够得到栈的最小元素的 min 函数在该栈中&#xff0c;调用 min、push 及 pop 的时间复杂度都是 O(1)。 MinStack minStack new MinStack(); minStack.push(-2); minStack.push(0); minStack.push(-3); minStack.min()…...

网络编程(Modbus进阶)

思维导图 Modbus RTU&#xff08;先学一点理论&#xff09; 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议&#xff0c;由 Modicon 公司&#xff08;现施耐德电气&#xff09;于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...

智慧医疗能源事业线深度画像分析(上)

引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...

微信小程序之bind和catch

这两个呢&#xff0c;都是绑定事件用的&#xff0c;具体使用有些小区别。 官方文档&#xff1a; 事件冒泡处理不同 bind&#xff1a;绑定的事件会向上冒泡&#xff0c;即触发当前组件的事件后&#xff0c;还会继续触发父组件的相同事件。例如&#xff0c;有一个子视图绑定了b…...

FastAPI 教程:从入门到实践

FastAPI 是一个现代、快速&#xff08;高性能&#xff09;的 Web 框架&#xff0c;用于构建 API&#xff0c;支持 Python 3.6。它基于标准 Python 类型提示&#xff0c;易于学习且功能强大。以下是一个完整的 FastAPI 入门教程&#xff0c;涵盖从环境搭建到创建并运行一个简单的…...

定时器任务——若依源码分析

分析util包下面的工具类schedule utils&#xff1a; ScheduleUtils 是若依中用于与 Quartz 框架交互的工具类&#xff0c;封装了定时任务的 创建、更新、暂停、删除等核心逻辑。 createScheduleJob createScheduleJob 用于将任务注册到 Quartz&#xff0c;先构建任务的 JobD…...

Nginx server_name 配置说明

Nginx 是一个高性能的反向代理和负载均衡服务器&#xff0c;其核心配置之一是 server 块中的 server_name 指令。server_name 决定了 Nginx 如何根据客户端请求的 Host 头匹配对应的虚拟主机&#xff08;Virtual Host&#xff09;。 1. 简介 Nginx 使用 server_name 指令来确定…...

Java多线程实现之Thread类深度解析

Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...

关键领域软件测试的突围之路:如何破解安全与效率的平衡难题

在数字化浪潮席卷全球的今天&#xff0c;软件系统已成为国家关键领域的核心战斗力。不同于普通商业软件&#xff0c;这些承载着国家安全使命的软件系统面临着前所未有的质量挑战——如何在确保绝对安全的前提下&#xff0c;实现高效测试与快速迭代&#xff1f;这一命题正考验着…...

【无标题】路径问题的革命性重构:基于二维拓扑收缩色动力学模型的零点隧穿理论

路径问题的革命性重构&#xff1a;基于二维拓扑收缩色动力学模型的零点隧穿理论 一、传统路径模型的根本缺陷 在经典正方形路径问题中&#xff08;图1&#xff09;&#xff1a; mermaid graph LR A((A)) --- B((B)) B --- C((C)) C --- D((D)) D --- A A -.- C[无直接路径] B -…...

【C++特殊工具与技术】优化内存分配(一):C++中的内存分配

目录 一、C 内存的基本概念​ 1.1 内存的物理与逻辑结构​ 1.2 C 程序的内存区域划分​ 二、栈内存分配​ 2.1 栈内存的特点​ 2.2 栈内存分配示例​ 三、堆内存分配​ 3.1 new和delete操作符​ 4.2 内存泄漏与悬空指针问题​ 4.3 new和delete的重载​ 四、智能指针…...