秋招后端开发面试题 - MySQL事务


目录

  • MySQL事务
    • 前言
    • 面试题
      • 什么是数据库事务
      • 为什么要有事务呢?
      • 项目中遇到的事务
      • 事务的传播机制
      • 事务的特性?
      • 事务并发存在的问题
      • 四大隔离级别
      • 四大隔离级别,都会存在哪些并发问题呢
      • 数据库是如何保证事务的隔离性的呢?
      • 如何解决加锁后的性能问题的?
      • 并发事务有什么什么问题?应该如何解决?
      • MySQL 事务实现原理是什么?
      • 事务的两阶段提交协议


MySQL事务

前言

已经找到工作了,分享秋招时的笔记。祝大家都能顺利找到自己心仪的工作。


面试题

什么是数据库事务

事务,由一个有限的数据库操作序列构成,这些操作要么全部执行,要么全部不执行

为什么要有事务呢?

  • 保证数据的最终一致性

项目中遇到的事务

  • 下单减库存

事务的传播机制

事务的特性?

ACID

  • 原子性: 事务作为一个整体被执行,包含在其中的对数据库的操作要么全部都执行,要么都不执行
  • 一致性: 指在事务开始之前和事务结束以后,数据不会被破坏
  • 隔离性: 多个事务并发访问时,事务之间是相互隔离
  • 持久性: 表示事务完成提交后,该事务对数据库所作的操作更改,将持久地保存在数据库之中

事务并发存在的问题

事务并发会引起脏读、不可重复读、幻读问题。

  • 脏读:一个事务读取到了另一个未提交事务修改过的数据
  • 不可重复读:同一个事务内,前后多次读取,读取到的数据内容不一致
  • 幻读:如果一个事务先根据某些搜索条件查询出一些记录,在该事务未提交时,另一个事务写入了记录,导致两次读取到的数据内容不一致

四大隔离级别

  • 读未提交: 只限制了两个数据不能同时修改,但是修改数据的时候,即使事务未提交,可以被别的事务读取到
  • 读已提交: 当前事务只能读取到其他事务提交的数据
  • 可重复读: 限制了读取数据的时候,不可以进行修改
  • 串行化: 事务最高的隔离级别,所有事务都是进行串行化顺序执行的

四大隔离级别,都会存在哪些并发问题呢

  • 读未提交:脏读、不可重复读、幻读
  • 读已提交:不可重复读、幻读
  • 可重复读:幻读
  • 串行化:无

数据库是如何保证事务的隔离性的呢?

  • 数据库是通过加锁,来实现事务的隔离性的
  • 比如串行化隔离级别就是加锁实现的,但是频繁的加锁,导致读数据时,没办法修改,修改数据时,没办法读取,大大降低了数据库性能

如何解决加锁后的性能问题的?

使用MVCC 多版本并发控制

并发事务有什么什么问题?应该如何解决?

并发事务可能造成:脏读、不可重复读和幻读等问题 ,这些问题其实都是数据库读一致性问题,必须由数据库提供一定的事务隔离机制来解决

  • 加锁:在读取数据前,对其加锁,阻止其他事务对数据进行修改
  • 提供数据多版本并发控制(MVCC),也称为多版本数据库:不用加任何锁, 通过一定机制生成一个数据请求时间点的一致性数据快照(Snapshot), 并用这个快照来提供一定级别的一致性读取,从用户的角度来看,好像是数据库可以提供同一数据的多个版本

MySQL 事务实现原理是什么?

以 InnoDB 的事务实现为例

  • InnoDB 是通过MVCC解决不可重复读问题
  • 间隙锁解决幻读问题
  • 事务的隔离性是通过实现
  • 而事务的原子性、一致性和持久性则是通过事务日志实现

事务的两阶段提交协议

  • 开启 binlog 的情况下,为了保证 binlog 与 redo log 的一致性,MySQL 将采用事务的两阶段提交协议
  • 当 MySQL 系统发生崩溃时,事务在存储引擎内部的状态可能为准备状态和提交状态两种
  • 对于准备状态的事务,是进行提交操作还是进行回滚操作,需要参考 binlog
    • 如果事务在 binlog 中存在,那么将其提交
    • 如果不在 binlog 中存在,回滚

秋招后端开发面试题系列目录
一、Java
1.1 Java基础上
1.2 Java基础下
1.3 Java集合
1.4 JavaIO
1.5 Java多线程上
1.6Java多线程下
二、JVM
2.1 JVM底层原理
2.2 垃圾回收器
2.3 垃圾回收算法
2.4 类加载机制
2.5 运行时数据区
三、MySQL
3.1 MySQL基础
3.2 事务
3.3 索引
3.4 锁机制
3.5 MVCC
四、Redis
4.1 Redis基础
4.2 缓存原理
五、中间件
5.1 RabbitMQ
六、Spring开源框架
6.1 Spring
6.2 Spring MVC
6.3 Spring Boot
6.4 MyBatis
七、操作系统
八、计算机网络
九、设计模式
十、微服务架构
十一、Spring Cloud分布式
11.1 分布式基础
11.2 Spring Cloud
11.3 GateWay
11.4 Nacos
11.5 OpenFeign
11.6 Ribbon
十二、算法
十三、项目

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

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

相关文章

各城市-人口就业和工资数据(1978-2022年)

这份数据收集了1978年至2022年间300多个地级市的人口、就业和工资等数据。涵盖的指标包括从业人员数量、平均工资水平、人口密度等,通过这些数据可以深入了解中国各地城市的人口结构、就业状况以及工资水平的变化趋势。这些数据对于研究城市发展、劳动力市场以及区域…

论文架构介绍

论文架构 背景:建议2段左右完成,字数控制在500左右为佳,对应子题目1过渡段:写150字左右的过渡段,承上启下,回答部分子题目2、3的要求正文实践部分:一般3-7个论点,根据题目的要求来看…

python基础--常用函数

常用函数 内建函数 在python里面可以直接使用的函数, 不需要使用import从其他文件里面导入 可以使用dir(__builtin__)进行查看 输入输出 print打印信息 print(*objects, sep , end\n, filesys.stdout, flushFalse)objects – 复数,表示可以一次输出多个对象。…

C++构造函数和析构函数的调用顺序

一般情况下,调用析构函数的次序正好与调用构造函数的次序相反,也就是最先被调用的构造函数,其对应的析构函数最后被调用,而最后被调用的构造函数,其对应的析构函数最先被调用。 当然对象的构造函数和析构函数调用时机和…

力扣100284. 有效单词(C++)

【题解】 (实际在力扣中运行的代码只需要把下方的check函数放到力扣作答区给的模板中就可以) #include <bits/stdc.h> #include <iostream> #include <vector> #include <string> #include <cctype> #include <cstring> #include <st…

融知财经:期货交易的规则和操作方法

期货交易是指在未来的某一特定时期&#xff0c;买卖双方通过签订合约的方式&#xff0c;约定以某种价格买卖一定数量的某种商品或资产的行为。期货交易的规则和操作方法如下&#xff1a; 期货交易的规则和操作方法 1、双向交易&#xff1a; 期货市场允许投资者进行多头&#xf…

Huffman树

输入 输入一共有2行。 第一行为一个整数n&#xff0c;它表示点的个数。 第二行有n(1 < n < 1000)个数&#xff0c;第i&#xff08;1 < i < n&#xff09;个数表示第i个点的权值 输出 输出为一个数&#xff0c;为最小造价值。 输入样例 1 点击复制 7 1 2 3 4 …

Windows MySQL本地服务器设置并导入数据库和数据

文章目录 小结问题及解决导出数据库Windows MySQL本地服务器设置导入数据库和数据 参考 小结 最近需要在本地Windows环境中设置MySQL服务器&#xff0c;并导入数据库和数据&#xff0c;记录过程。 问题及解决 导出数据库 首先需要导出数据库&#xff1a; C:\mysql-8.0.37-…

Python ArcPy批量将大量栅格文件的投影坐标系转为地理坐标系

本文介绍基于Python语言中的ArcPy模块&#xff0c;批量将多个遥感影像由投影坐标系转为地理坐标系的方法。 在之前的文章中&#xff0c;我们介绍过将单独1景遥感影像的投影坐标系转为地理坐标系的方法&#xff0c;大家可以参考文章投影坐标系转为地理坐标系&#xff1a;GDAL命令…

笔记86:关于【#ifndef + #define + #endif】的用法

当你在编写一个头文件&#xff08;例如 pid_controller.h&#xff09;时&#xff0c;你可能会在多个源文件中包含它&#xff0c;以便在这些源文件中使用该头文件定义的函数、类或其他声明。如果你在多个源文件中都包含了同一个头文件&#xff0c;那么当你将整个工程统一编译&am…

第六节课《Lagent AgentLego 智能体应用搭建》

PDF链接&#xff1a;https://pan.baidu.com/s/1JFtvBWgEGFWJq8pHafvIUg?pwd6666 提取码&#xff1a;6666 Lagent & AgentLego 智能体应用搭建_哔哩哔哩_bilibili https://github.com/InternLM/Tutorial/blob/camp2/agent/README.md InternStudio 一、为什么需要agent…

基于JSP的酒店客房管理系统(三)

目录 第四章 系统各模块的实现 4.1客房管理系统首页的实现 4.1.1 客房管理系统首页概述 4.2客房管理系统前台的实现 4.2.1 客房管理系统前台概述 4.2.2 客房管理系统前台实现过程 4.2.3 预定客房信息及客房信息的查询 4.3客房管理系统后台的实现 4.3.1 客房管理系统后…

微搭低代码入门05文件的上传和下载

目录 1 创建数据源2 创建应用3 创建页面4 设置导航功能5 文件上传6 文件下载总结 小程序中&#xff0c;我们通常会有文件的上传和下载的需&#xff0c;在微搭中&#xff0c;文件是存放在云存储中&#xff0c;每一个文件都会有一个唯一的fileid&#xff0c;我们本篇就介绍如何通…

Unity类银河恶魔城学习记录 17-1,2 p166 Aliments fx p167 Blackhole additional vfx

Alex教程每一P的教程原代码加上我自己的理解初步理解写的注释&#xff0c;可供学习Alex教程的人参考 此代码仅为较上一P有所改变的代码 【Unity教程】从0编程制作类银河恶魔城游戏_哔哩哔哩_bilibili Entity.cs using System.Collections; using System.Collections.Generic; …

智能Agent:未来社会的角色、发展路径与挑战

​​​​​​​ 随着人工智能技术的不断发展&#xff0c;智能Agent已经成为了我们生活中越来越重要的一部分。从智能助手到自动驾驶汽车&#xff0c;再到语音助手和智能家居系统&#xff0c;智能Agent正在以多种形式渗透到我们的日常生活中。但随着Agent AI的智能化水平不断提…

第Ⅷ章-Ⅰ 组合式API初识

第Ⅷ章-Ⅰ 组合式API初识 简介setup 函数 为什么要使用Composition API逻辑复用和组织更灵活的逻辑组合适应未来的 Vue 生态系统 options API存在的问题代码重复&#xff1a;逻辑分散缺乏复用性 Composition API 中的 setup()入口props 参数context 参数 ref 响应式监听reactiv…

Vue3(管理系统)-封装axios(utils)

一、在utils下编写request.js实例 1.添加基地址&#xff0c;设置超时时间 import axios from axios const baseURL http://big-event-vue-api-t.itheima.net const instance axios.create({// TODO 1. 基础地址&#xff0c;超时时间baseURL,timeout: 3000 }) 2.添加请求拦截…

[C++][数据结构]红黑树的介绍和模拟实现

前言 之前我们简单学习了一下搜索树和平衡搜索树&#xff0c;今天我们来学习一下红黑树 简介 概念 红黑树&#xff0c;是一种二叉搜索树&#xff0c;但在每个结点上增加一个存储位表示结点的颜色&#xff0c;可以是Red或Black。 通过对任何一条从根到叶子的路径上各个结点着…

为什么技术面一般不谈薪资?

我这些年做了很招聘工作&#xff0c;一般都被告知在技术面时不谈论薪资。 其实我一直觉得挺麻烦的&#xff0c;这人不就是我决定要不要吗&#xff1f; 我除了评估技术能力是否合格&#xff0c;再根据开价情况来做决定不就完事吗。每次面完我再等着HR去谈完薪资&#xff0c;然…

面试官:关于HTTPS/HTTP2/HTTP3你懂多少?

公众号&#xff1a;程序员白特&#xff0c;欢迎一起交流学习~ HTTPS是什么 HTTP为什么不安全&#xff1f; https被认为是通信安全的http&#xff0c;除了http多了s和默认端口改成了443之外&#xff0c;其他都是沿用的http&#xff08;除了明文和不安全&#xff09;&#xff0…