排序
面试题:为什么 MySQL 选择使用 B+ 树作为索引结构?
MySQL 选择使用 B+ 树 作为索引结构,是基于其对 磁盘 I/O 性能优化、范围查询效率 和 数据存储特性 的综合考量。以下是详细分析: 1. 为什么 B+ 树比 B 树更适...
面试题:什么是数据库的逻辑删除?数据库的物理删除和逻辑删除有什么区别?
逻辑删除与物理删除的概念 逻辑删除:指的是在数据库中不实际移除数据记录,而是通过标记的方式(如增加一个is_deleted字段,并将其值设为true或1)来表示该记录已被“删除”。这样做的好处是可...
面试题:详细描述一条 SQL 语句在 MySQL 中的执行过程。
一条 SQL 语句在 MySQL 中的执行过程涉及多个层次和组件的协同工作。以下是详细的执行流程,结合 MySQL 的架构(Server 层和存储引擎层)进行说明: 一、执行流程概览 客户端发送请求 连接管理...
面试题:MySQL 的查询优化器如何选择执行计划?
MySQL的查询优化器在决定执行计划时会考虑多种因素,以确保查询尽可能高效地运行。以下是优化器选择执行计划时的一些关键步骤和考虑因素: 统计信息:MySQL使用表和索引的统计信息来评估不同执...
面试题:MySQL 的 Change Buffer 是什么?它有什么作用?
MySQL 的 Change Buffer 是什么?它有什么作用? 1. 定义与核心作用 Change Buffer 是 MySQL InnoDB 存储引擎 中的一个关键优化机制,主要用于缓存对 非唯一二级索引(如普...
面试题:MySQL 中有哪些锁类型?
在 MySQL 中,锁机制对于确保数据的一致性和完整性至关重要。MySQL 支持多种类型的锁,主要包括表级锁和行级锁,不同存储引擎对锁的支持有所不同。以下是 MySQL 中主要的锁类型: 表级锁(Table...
面试题:数据库的脏读、不可重复读和幻读分别是什么?
在数据库事务管理中,脏读、不可重复读和幻读是三种常见的并发问题,它们描述了当多个事务同时访问相同的数据时可能出现的问题。以下是这三个概念的详细解释: 1. 脏读(Dirty Read) 定义:脏...
面试题:如何在 MySQL 中避免单点故障?
在 MySQL 中避免单点故障(Single Point of Failure, SPOF)是确保数据库高可用性和系统稳定性的核心目标。以下是实现这一目标的主要技术和策略,结合 主从复制、集群方案、自动化工具&nbs...
面试题:MySQL 在设计表(建表)时需要注意什么?
在设计MySQL表(建表)时,有多个方面需要考虑以确保数据库的性能、可维护性和数据完整性。以下是一些关键点: 选择合适的数据类型:为每个字段选择最合适的数据类型非常重要。例如,使用INT而...
面试题:MySQL 的索引类型有哪些?
MySQL 的索引类型可以从多个维度进行分类,以下是常见的索引类型及其特点、适用场景和创建方式的总结: 一、按数据结构分类 B-Tree 索引(默认索引类型) 特点: 基于平衡多路搜索树(B+树)实...
