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

MySQL面试题全解析:准备面试所需的关键知识点和实战经验

MySQL有哪几种数据存储引擎?有什么区别?

MySQL支持多种数据存储引擎,其中最常见的是MyISAM和InnoDB引擎。可以通过使用"show engines"命令查看MySQL支持的存储引擎。

  1. 存储方式:MyISAM引擎将数据和索引分别存储在两个不同的文件中,一个是.MYD文件用于存储数据,一个是.MYI文件用于存储索引。而InnoDB引擎将数据和索引存储在同一个文件中。
  2. 锁机制:MyISAM引擎只支持表级锁,即在对某个表进行读写时,会锁住整个表,其他操作需要等待。而InnoDB引擎支持行级锁,可以在并发访问时只锁住需要操作的行,提高了并发性能。
  3. 事务支持:MyISAM引擎不支持事务,而InnoDB引擎支持事务。事务是一种保证数据一致性和完整性的机制,可以将多个操作作为一个整体进行提交或回滚。
  4. 外键支持:MyISAM引擎不支持外键约束,而InnoDB引擎支持外键约束。外键是用于维护表与表之间关系的一种机制,可以确保数据的一致性

什么是脏读、幻读、不可重复读?要怎么处理?

脏读、不可重复读和幻读是数据库中的一些并发问题。

脏读是指一个事务在读取另一个未提交事务的数据时,如果未提交事务回滚了,则读取到的数据是不一致的。

不可重复读是指一个事务在相同的查询条件下,多次读取数据结果不一致。例如,事务A第一次读取数据时,事务B修改了相同的数据并提交,导致事务A第二次读取时数据不一致。

幻读是指一个事务在多次查询中,由于其他事务插入或删除数据,导致查询结果出现新增或减少的情况。

处理这些问题的方法有几种:

  1. 加锁:可以使用数据库提供的锁机制,如行级锁或表级锁,来控制并发访问,确保数据的一致性。但是加锁会降低并发性能。需要自己根据业务需要添加共享锁还是排它锁。
  2. 调整事务隔离级别:数据库提供了不同的事务隔离级别,如读未提交、读已提交、可重复读和串行化。可以根据具体情况选择合适的隔离级别来避免并发问题。

事务的基本特性和隔离级别有哪些?

事务的基本特性包括ACID:

  1. 原子性(Atomicity):一个事务中的所有操作要么全部成功提交,要么全部失败回滚。事务是一个不可分割的工作单位,要么全部执行,要么全部不执行。
  2. 一致性(Consistency):事务执行前后,数据库的完整性约束没有被破坏。事务的操作会将数据库从一个一致性状态转换为另一个一致性状态。
  3. 隔离性(Isolation):并发执行的事务之间应该相互隔离,一个事务的执行不应该被其他事务干扰。隔离性确保每个事务在并发环境中都能独立执行,不会受其他事务的影响。
  4. 持久性(Durability):一旦事务提交成功,其所做的修改将永久保存在数据库中。即使发生系统崩溃或电源故障,数据库也能够恢复到事务提交后的状态。

隔离级别是控制事务隔离性的一个参数,常见的隔离级别包括:

  1. 读未提交(Read Uncommitted):最低级别的隔离级别,允许一个事务读取另一个事务未提交的数据。会出现脏读问题。
  2. 读已提交(Read Committed):保证一个事务只能读取到其他事务已经提交的数据,解决了脏读问题。但是可能会出现不可重复读问题。
  3. 可重复读(Repeatable Read):保证在一个事务中多次读取同一数据时,得到的结果是一致的。解决了不可重复读问题。但是可能会出现幻读问题。
  4. 串行化(Serializable):最高级别的隔离级别,要求事务串行执行,避免了幻读问题。但是会降低并发性能。

MySQL的锁有哪些?什么是间隙锁?

MySQL的锁可以根据锁的粒度进行划分,包括行锁、表锁和全局锁。下面是对每种锁的详细说明:

行锁:InnoDB引擎支持行锁,它的粒度很小,可以提供较好的并发性能,但是会消耗更多的资源。行锁又可以细分为以下两种:

  • 共享锁:使用SELECT ** LOCK IN SHARE MODE语句来获取共享锁,读取操作期间可以共享,但会阻塞写操作。
  • 排它锁:使用SELECT ** FOR UPDATE语句来获取排它锁,各种操作都会被阻塞,而且在执行INSERT、DELETE、UPDATE语句时会自动添加排它锁。
  • 自增锁:当涉及到自增字段时,每次获取自增值时都会进行阻塞。需要注意的是,自增锁与业务逻辑无关。

表锁:直接锁住整张表而不是单独的行,表锁消耗的资源比较少,但是锁的粒度较大,导致并发性能较低。表锁可以细分为以下两种:

  • 表共享锁:多个会话可以同时获取表的共享锁,读操作可以并发进行,但是写(INSERT、DELETE、UPDATE)会被阻塞。
  • 表排它锁:获取表排它锁的会话会阻塞其他会话的所有操作,包括读和写。

全局锁:使用FLUSH TABLES WITH READ LOCK语句来获取全局锁,通常用于表数据备份等场景。

间隙锁(Gap Lock)主要针对带有索引的字段。例如,对于一个拥有user_id索引的user表(user_id, name),数据有(1,a)(4,b)(9,c),当执行UPDATE user SET name = d WHERE user_id = 5时,会锁定 5-9 之间的记录(不包括自身)。而执行UPDATE user SET name = 5 WHERE user_id = 4时,则是记录锁,只锁住一条记录。

另一种类型是Next-Key锁,它实际上是右侧界的记录锁。对于上述user表的索引,Next-Key锁会在(1, a)、(4, b)、(9, c)之间进行锁定。表示从左开区间到右开区间封闭,即( -∞, 1], (1, 4], (4, 9], (9, +∞)。这样可以确保范围内的记录都受到锁的保护。

通过使用间隙锁和Next-Key锁,可以更精确地控制并发操作,提高数据库的数据一致性和并发性能。

MySQL的索引结构是什么样的?聚簇索引和非聚簇索引又是什么?

MySQL是一种广泛使用的关系型数据库管理系统,具有多种存储引擎和索引结构可供选择。存储引擎是MySQL用来处理数据的核心组件,而索引结构则用于提高数据检索的效率。

在MySQL中,最常见和常用的存储引擎是InnoDB和MyISAM。InnoDB是一个支持事务处理和行级锁定的存储引擎,适用于处理大量并发操作和高可靠性要求的应用。而MyISAM则是一个更适合于读写不频繁的应用,它不支持事务处理,但速度较快。

索引结构是用来加快数据检索速度的一种数据结构。

  • B+树索引是MySQL中最常见的索引结构。它使用B+树的数据结构来存储索引值和对应的数据行位置。非叶子节点只存储索引值,叶子节点存储索引值和对应的数据行位置。B+树索引的叶子节点按照索引值的顺序排列,并且通过双向链表连接,使得范围查询和最左前缀匹配查询更高效。
  • 哈希索引将索引值通过哈希函数映射为一个唯一的哈希值,并将哈希值和对应的数据行位置存储在哈希表中。哈希索引适用于等值查询,但不支持范围查询和模糊查询。

聚簇索引是索引值和表的数据存储在一起的索引结构。在InnoDB存储引擎中,聚簇索引使用B+树来实现,叶子节点存储数据行的实际数据。一个表只能有一个聚簇索引,如果没有显式指定主键,那么会找第一个unique字段当做主键索引,否则将会使用隐藏的rowid作为主键索引。

非聚簇索引是索引值和表的数据分开存储的索引结构。在MyISAM存储引擎中,每个索引都是一个独立的文件,存储索引值和对应的数据行位置。一张表可以有多个非聚簇索引,比如表的普通索引。

MySQL的覆盖索引和回表

覆盖索引是指索引包含了查询所需的所有字段,这样在查询时就可以直接使用索引中的数据,而无需回表去读取数据行。这种方式可以减少磁盘I/O操作,提高查询性能。

当一个查询只需要从索引中获取数据而不需要回表时,就可以称之为覆盖索引查询。在这种情况下,数据库引擎只需要读取索引页,而不需要再去读取数据页,从而节省了磁盘I/O开销。

使用覆盖索引可以提高查询性能的原因是,索引通常比数据行小很多,所以从索引中读取数据比从数据行中读取数据更快。此外,覆盖索引还可以减少内存的使用,因为不需要将数据行加载到内存中进行处理。

为了使用覆盖索引,需要确保查询语句中只包含索引字段,并且索引能够满足查询条件和排序需求。如果查询语句中包含了非索引字段,那么数据库引擎仍然需要回表去读取数据行,无法实现覆盖索引查询的优化效果。

MySQL的集群是如何搭建的?读写分离是怎么做的?

image

MySQL的集群搭建通常使用主从复制的方式,并结合读写分离来提高数据库的性能和可用性。

首先,在搭建MySQL集群之前,需要确定一个主节点和多个从节点。主节点负责处理写操作,从节点负责处理读操作。

在主节点接收到写操作时,会将修改的数据记录到binlog日志中。binlog是二进制日志,用于记录数据库的所有修改操作。从节点会定期读取主节点的binlog日志,并将这些操作应用到自己的数据库中,实现主从数据的同步。

通常情况下,当一个未提交的事务进行操作数据时,首先写入到undolog,其次写入redolog和binlog,但是提交事务之前并不会写入磁盘,只是在内存中,这种设计可以提高数据库的性能,因为将数据写入磁盘是比较耗时的操作,而将数据暂时保存在内存中可以减少磁盘访问的次数,从而提高数据库的处理速度。

在读写分离的架构中,还需要考虑主从复制的延迟问题。由于主从复制是异步的,所以从节点上的数据可能不是实时同步的。可以通过设置合适的复制延迟时间来平衡数据的一致性和性能的需求。

半同步复制是MySQL主从复制的一种机制,它在传输binlog日志时,主节点需要等待至少一个从节点确认收到并写入日志后才能继续进行下一步操作。

具体的工作流程如下:

  1. 当主节点完成一次事务的提交后,它会将binlog日志发送给一个或多个从节点。
  2. 主节点会等待至少一个从节点将binlog日志写入磁盘并发送一个确认消息给主节点。
  3. 一旦主节点收到至少一个从节点的确认消息,它才会认为该次提交已经完成,可以继续进行下一次操作。

谈谈如何对MySQL进行分库分表?多大数据量需要进行分库分表?分库分表的方式和分片策略由哪些?分库分表后,SQL语句的执行流程是怎样的?

分库分表是一种常用的数据库架构优化技术,用于应对数据规模不断增长的情况。分库分表可以通过纵向拆分和横向拆分两种方式进行。

  • 纵向拆分是将不同的业务数据分开存储在不同的数据库中,每个数据库对应一个业务。这样可以有效避免单一数据库数据量过大导致的性能问题,但无法解决单个业务数据量过大的查询问题。
  • 横向拆分是将单个表中的数据按照某些字段进行拆分,将数据分散存储在多个表中。这样可以减小单个表的数据量,提高查询效率。常见的分片策略有按照范围、按照哈希和按照取模等。

分库分表会引入新的问题,例如数据的拆分和合并、开发和维护的复杂度增加等。因此,在选择分库分表之前,需要根据业务的增长速度和数据量来判断是否需要进行分库分表。根据阿里的开发规范手册,一般在数据量达到500万或单个表文件大小增长到2G时,可以考虑进行分库分表的规划。

通常,可以使用一些开源的分库分表中间件,如Mycat或ShardingSphere,来实现分库分表功能。这些中间件支持DDL、DML等语句的执行,能够进行排序、分组聚合等操作。但对于一些复杂的SQL语句,如子查询,可能存在一定的限制。

image

SQL语句的执行流程一般包括解析、优化、路由、分片和归并结果集等步骤。首先,数据库会对SQL语句进行解析,将其转换成内部数据结构。然后,通过优化器对SQL语句进行优化,生成最优的执行计划。接下来,根据分片策略,确定需要执行的数据库和表。然后,将SQL语句发送到相应的数据库节点执行。最后,将执行结果进行归并,返回给用户

总结

本次种子题目主要涵盖了MySQL的存储引擎和索引结构,如B+树索引和哈希索引,以及覆盖索引和回表的概念。此外,还包含了MySQL事务的ACID特性和隔离级别。另外,对MySQL主从集群中的binlog日志的执行顺序和作用进行了讨论。最后,还涉及了分库分表和读写分离的概念。这些内容涵盖了MySQL数据库的核心知识和重要技术,不仅在面试中起到关键作用还对于优化数据库性能和应用开发都具有重要意义。


我是努力的小雨,一名 Java 服务端码农,潜心研究着 AI 技术的奥秘。我热爱技术交流与分享,对开源社区充满热情。同时也是一位掘金优秀作者、腾讯云内容共创官、阿里云专家博主、华为云云享专家。

💡 我将不吝分享我在技术道路上的个人探索与经验,希望能为你的学习与成长带来一些启发与帮助。

🌟 欢迎关注努力的小雨!🌟

相关文章:

MySQL面试题全解析:准备面试所需的关键知识点和实战经验

MySQL有哪几种数据存储引擎?有什么区别? MySQL支持多种数据存储引擎,其中最常见的是MyISAM和InnoDB引擎。可以通过使用"show engines"命令查看MySQL支持的存储引擎。 存储方式:MyISAM引擎将数据和索引分别存储在两个不…...

01_Electron 跨平台桌面应用开发介绍

Electron 跨平台桌面应用开发介绍 一、Electron 的介绍二、关于 NW.js 和 Electron 介绍三、搭建 Electron 的环境1、准备工作:2、安装 electron 环境3、查看 electron 的版本,electron -v 一、Electron 的介绍 Electron 是由 Github 开发的一个跨平台的…...

【C语言-扫雷游戏】mineweeper【未完成】

编程小白如何成为大神?大学新生的最佳入门攻略 编程已成为当代大学生的必备技能,但面对众多编程语言和学习资源,新生们常常感到迷茫。如何选择适合自己的编程语言?如何制定有效的学习计划?如何避免常见的学习陷阱&…...

psychopy stroop 实验设计

斯特鲁stroop实验就是色词一致/不一致实验。 设计步骤如下: 1. 先去设置中将Input改为PsychToolbox, 2. 然后左上角File-New新建一个 3. 右键trial,rename改名 改成自己想要的名字即可,比如欢迎界面welcome。 4. 接下来添加提示语…...

c++精品小游戏(无错畅玩版)

一、俄罗斯方块 #include <stdio.h> #include <string.h> #include <stdlib.h> #include <time.h> #include <conio.h> #include <windows.h>#ifdef _MSC_VER // M$的编译器要给予特殊照顾 #if _MSC_VER < 1200 // VC6及以下版本 #err…...

应急响应-主机安全之系统及进程排查相关命令(Linux操作系统-初级篇)

目录 概述lscpu-显示有关CPU架构的信息uname-查看系统信息lsmod-输出加载的所有模块lastb-输出最后登录失败的用户last-展示用户最近登录信息lastlog-展示所有用户最后的登录时间systemctl-系统服务&#xff0c;开机自启排查crontab-计划任务选项 history-查看历史命令选项常用…...

java中RSA分段加解密及Data must not be longer than异常处理

谈到RSA非对称加密&#xff0c;作为开发的我们第一想到的是安全&#xff0c;几乎不会被破解&#xff0c;以及公钥加密&#xff0c;私钥解密这些。在Java代码中&#xff0c;我们常使用一些现成的工具类如hutool中提供的工具类、网上在线的或者博客上的RSAUtils工具类来实现公钥私…...

MySQL数据分析进阶(十二)设计数据库——PART3

※食用指南&#xff1a;文章内容为‘CodeWithMosh’SQL进阶教程系列学习笔记&#xff0c;笔记整理比较粗糙&#xff0c;主要目的自存为主&#xff0c;记录完整的学习过程。&#xff08;图片超级多&#xff0c;慎看&#xff01;&#xff09; 【中字】SQL进阶教程 | 史上最易懂S…...

Kubernetes-1.22.0 可视化部署

目录 Kubeadm方式部署3master&#xff0c;2work集群&#xff08;Kubernetes-1.22.0&#xff09;-CSDN博客 1. 官方Dashboard 2. Kuboard 部署 3. Rainbond 部署 4. Kubesphere 部署 1. 官方Dashboard kubectl apply -f https://kuboard.cn/install-script/k8s-dashboard/v2…...

在 vue3 中动态路由问题记录

第一种 如果这样子的话需要加上 /* vite-ignore / ,但是在这样用这行部署服务器上跳转会有问题 component: () > import(/ vite-ignore */ ../views/ e.component .vue) 第二种 // 解决跳转问题const modeules imporet.meta.glob(/views/**/**.vue)component: modules…...

进程编程及其函数的使用

1. 创建进程 创建进程的核心操作是使用 fork() 系统调用。 1.1 fork() 系统调用 fork() 创建一个新进程&#xff08;子进程&#xff09;&#xff0c;新进程几乎是父进程的完整拷贝。fork() 返回两次&#xff1a; 在父进程中&#xff0c;返回子进程的 PID。在子进程中&#…...

为什么funnel图在邮件中不显示

在电子邮件中嵌入的Funnel图或其他图表可能不显示的原因有以下几种&#xff1a; 1. 邮件客户端对外部内容的限制 大多数邮件客户端为了安全&#xff0c;会阻止从外部服务器加载的内容&#xff0c;如图片、脚本或嵌入式图表。Funnel图通常是通过链接或外部脚本生成的&#xff…...

C语言 ——— 写一个函数,判断一个字符串是否为另外一个字符串旋转之后的字符串

目录 题目要求 代码思路 代码实现 题目要求 写一个函数&#xff0c;判断一个字符串是否为另外一个字符串旋转之后的字符串 例如 s1 "AABCD" &#xff1b;s2 "BCDAA" &#xff0c;返回1 s1 "AABcd" &#xff1b;s2 "BCDAA" …...

白骑士的Matlab教学实战项目篇 4.4 机器学习与AI

系列目录 上一篇&#xff1a;白骑士的Matlab教学实战项目篇 4.3 控制系统设计 机器学习与人工智能&#xff08;AI&#xff09;是当前技术发展的前沿领域&#xff0c;通过数据驱动的模型和算法&#xff0c;可以解决许多复杂的问题。MATLAB 提供了丰富的工具和函数&#xff0c;支…...

事件监控模块——Channel模块

这个模块就是 记录文件描述符 和 想要监控的事件&#xff0c;实际就绪的事件&#xff0c;以及事件发生之后要怎么做&#xff0c;判断有没有监控这个事件&#xff0c;获取事件。 class Poller; class EventLoop; class Channel {private:int _fd;EventLoop *_loop;uint32_t _ev…...

OCR调研

OCR调研 一、介绍 OCR&#xff08;Optical Character Recognition&#xff0c;光学字符识别&#xff09;是一种将图像中的文字转换为计算机可处理格式的技术。OCR技术经历了从传统OCR到基于深度学习的OCR的转变。深度学习OCR技术通过模拟人脑神经元结构处理文本和图像数据&am…...

数据结构(学习版)

考纲 (一)数据结构部分; 线性表栈、队列、数组查找和内部排序树和图 (二)计算机算法设计部分: 递归与分省策路、回溯法贪心算法、分支限界法、动态规划算法设计中的数据结构运用 (三)程序设计基础(C或C)部分: 基本数据类型、各种运算符和表达式、基本控制结构。数组的定义…...

除了知云文献翻译外,这几款翻译工具值得推荐!

近年来&#xff0c;市面上涌现出众多优秀的文献翻译工具&#xff0c;其中知云文献翻译凭借其强大的功能受到了广泛好评。然而&#xff0c;除了知云文献翻译外&#xff0c;还有几款翻译工具同样值得推荐。今天&#xff0c;就让我们一起来了解一下&#xff01; Foxit在线翻译 链…...

Element UI动态实现面包屑导航~

思路&#xff1a;监听路由变化&#xff0c;在路由规则中添加meta然后在组件中渲染。 import Vue from "vue" import VueRouter from "vue-router" Vue.use(VueRouter) // 解决ElementUI导航栏中的vue-router在3.0版本以上重复点菜单报错问题 const origin…...

安科瑞Acrel-2000ES储能能量管理系统在新型电力系统下分布式储能的研究

摘要&#xff1a;传统电力系统的结构和运行模式在以新能源为主体的新型电力系统中发生了巨大的变化&#xff0c;分布式储能作为电力系统中重要的能量调节器&#xff0c;也迎来了新的发展机遇。立足于储能技术发展现状&#xff0c;分析了分布式储能技术特点及在清洁可再生能源方…...

Git 逆转时光:版本回退操作详解

git 版本回退操作详解 一、Git的工作流程二、git clean尚未 commit 的修改三、已经 commit 尚未 push 到 remote 仓库四、已经提交到 remote 仓库五、回退建议六、总结 一、Git的工作流程 在讲这个版本回退之前&#xff0c;我们要温习一下Git的原理。下面这张图就是 Git 的整个…...

8.6.数据库基础技术-数据库的控制

并非控制 事务&#xff1a;由一系列DML操作组成&#xff0c;这些操作&#xff0c;要么全做&#xff0c;要么全不做&#xff0c;它从第一个DML操作开始&#xff0c;rollback、commit或者DDL结束&#xff0c;拥有以下四种特性&#xff0c;详解如下&#xff1a; &#xff08;操作)…...

php语言基础入门

文章目录 php语言基础入门一、简介二、基础语法1、变量2、常量3、注释4、基础数据类型4.1、整形数据类型4.2、布尔数据类型4.3、字符串数据类型4.4、浮点型数据类型4.5、PHP数据类型之查看和判断数据类型 5、流程控制5.1、if-elseif-else语句使用5.2、switch语句使用5.3、while…...

告别杂音,从 AI 音频降噪开始

生活中&#xff0c;音频无处不在。无论是聆听动人的音乐&#xff0c;还是参与重要的电话会议&#xff0c;又或是沉浸于精彩的网课学习&#xff0c;清晰、纯净的音频质量都至关重要。然而&#xff0c;音频中的噪声却像不速之客&#xff0c;扰乱着这份美好。 音频中的噪声形式多样…...

Postman中params传参与Body传参区别以及Body中不同类型的区别

Postman中params传参与Body传参区别 在HTTP请求中&#xff0c;参数可以通过不同的方式传递给服务器&#xff0c;其中最常见的两种方式是使用params&#xff08;查询参数&#xff09;和body&#xff08;请求体&#xff09;。以下是它们的主要区别&#xff1a; 1. 位置&#xf…...

数据结构入门——05队列

1.队列 队列&#xff1a;只允许在一端进行插入数据操作&#xff0c;在另一端进行删除数据操作的特殊线性表&#xff0c;队列具有先 进先出FIFO(First In First Out) 入队列&#xff1a;进行插入操作的一端称为队尾出队列&#xff1a;进行删除操作的一端称为队头 队列也可以数…...

使用python MySQL 实现一个 key-value(string:json) 读写库

在Python中,我们可以使用`pymysql`库(如果MySQL服务器版本较高,也推荐使用`mysql-connector-python`)来建立一个简单的key-value存储库,其中键是字符串,值是JSON格式的数据。这里我们创建一个基本的类来完成读写操作: import pymysql.cursors import jsonclass JsonKVS…...

实现:uniapp项目分享视频页面到微信,可以自定义分享的页面样式及内容

背景&#xff1a;最近在逐步完善一个uniapp项目的视频功能&#xff0c; 包括有视频录制及发布&#xff0c;在完善过程中想要实现分享 视频到微信的功能&#xff0c;也就是相当于分享链接到微信&#xff0c; 微信打开后可以获取到视频并可以观看&#xff0c;有了想法便 准备实行…...

【C++】—— 类与对象(五)

【C】—— 类与对象&#xff08;五&#xff09; 1、类型转换1.1、类型转换介绍1.2、类型转换的应用1.3、explicit 关键字 2、static 静态成员2.1、static 静态成员变量2.2、static 静态成员函数2.3、总结 3、友元3.1、友元函数3.2、友元类 4.内部类5、匿名对象6、对象拷贝时的编…...

scp命令的使用

在Windows和Linux之间传文件&#xff0c;最简单的是共享目录&#xff0c;如果不能使用共享目录&#xff0c;可以使用scp命令&#xff0c; 一般Windows和Linux都支持。 scp命令是secure copy的缩写&#xff0c;用于在Linux下进行远程文件拷贝&#xff0c;windows一般也有该命令…...