MySQL 面试题共74篇

MySQL 是主流的开源关系型数据库管理系统,是后端开发者必备的技能。MySQL 面试的重点包括数据表设计、SQL 查询、索引优化、事务管理、锁机制、存储引擎(如 InnoDB)、高并发处理和性能调优等。

面试题:什么是数据库的逻辑外键?数据库的物理外键和逻辑外键各有什么优缺点?

在数据库设计中,外键(Foreign Key)用于定义和加强两个表之间的关系。根据其实现方式的不同,可以将外键分为物理外键和逻辑外键。 物理外键 定义:物理外键指的是通过数据库管理系统(DBMS)明...
程序百科的头像-程序百科程序百科9个月前
5313

场景题:如果组长要求你主导项目中的分库分表,大致的实施流程是?

主导分库分表的实施流程 1. 需求分析与方案设计 明确目标 解决单库单表性能瓶颈(如查询延迟、写入吞吐不足)。 支持未来3-5年的业务增长(预估数据量、并发量)。 是否需要支持高可用、弹性扩...
程序百科的头像-程序百科程序百科8个月前
4911

面试题:MySQL 的存储引擎有哪些?它们之间有什么区别?

MySQL 的存储引擎是其核心功能之一,不同的存储引擎支持不同的特性、性能优化和适用场景。以下是常见的 MySQL 存储引擎及其区别: 一、常见存储引擎 InnoDB(默认引擎) 特点: 事务支持:支持 ...
程序百科的头像-程序百科程序百科8个月前
5414

面试题:MySQL 中 VARCHAR(100) 和 VARCHAR(10) 的区别是什么?

在 MySQL 中,VARCHAR(10) 和 VARCHAR(100) 是变长字符串类型,它们的主要区别在于最大字符长度限制和性能影响。以下是详细对比: 1. 存储长度限制 VARCHAR(10) 最多存储 10 个字符。 插入的数...
程序百科的头像-程序百科程序百科9个月前
8415

面试题:MySQL 中如果发生死锁应该如何解决?

在 MySQL 中,死锁是指两个或多个事务在等待对方释放资源,从而导致这些事务永远处于等待状态的情况。MySQL 的 InnoDB 存储引擎能够自动检测到死锁,并回滚其中一个事务来解决这个问题。 然而,...
程序百科的头像-程序百科程序百科8个月前
517

面试题:MySQL 中 LIMIT 100000000, 10 和 LIMIT 10 的执行速度是否相同?

在 MySQL 中,LIMIT 100000000, 10 和 LIMIT 10 的执行速度 完全不同,且 LIMIT 10 明显更快。以下是详细分析: 1. 核心原因:偏移量(OFFSET)的处理 LIMIT 10 ...
程序百科的头像-程序百科程序百科8个月前
579

面试题:请详细描述 MySQL 的 B+ 树中查询数据的全过程

MySQL 的 B+ 树 是 InnoDB 存储引擎实现索引的核心数据结构。查询数据的过程涉及从根节点逐层向下查找,最终在叶子节点定位目标数据。以下是基于 聚簇索引(主键索引) 和&...
程序百科的头像-程序百科程序百科8个月前
8010

面试题:什么是数据库的逻辑删除?数据库的物理删除和逻辑删除有什么区别?

逻辑删除与物理删除的概念 逻辑删除:指的是在数据库中不实际移除数据记录,而是通过标记的方式(如增加一个is_deleted字段,并将其值设为true或1)来表示该记录已被“删除”。这样做的好处是可...
程序百科的头像-程序百科程序百科9个月前
238

面试题:什么是分库分表?分库分表有哪些类型(或策略)?

分库分表的定义 分库分表是一种数据库优化技术,用于解决单库单表性能瓶颈的问题。当数据量过大或并发访问压力过高时,将原本集中存储的数据分散到多个数据库或多个表中,从而提升数据库的性能...
程序百科的头像-程序百科程序百科8个月前
2915

面试题:详细描述一条 SQL 语句在 MySQL 中的执行过程。

一条 SQL 语句在 MySQL 中的执行过程涉及多个层次和组件的协同工作。以下是详细的执行流程,结合 MySQL 的架构(Server 层和存储引擎层)进行说明: 一、执行流程概览 客户端发送请求 连接管理...
程序百科的头像-程序百科程序百科8个月前
248