排序
面试题:什么是数据库的逻辑外键?数据库的物理外键和逻辑外键各有什么优缺点?
在数据库设计中,外键(Foreign Key)用于定义和加强两个表之间的关系。根据其实现方式的不同,可以将外键分为物理外键和逻辑外键。 物理外键 定义:物理外键指的是通过数据库管理系统(DBMS)明...
场景题:如果组长要求你主导项目中的分库分表,大致的实施流程是?
主导分库分表的实施流程 1. 需求分析与方案设计 明确目标 解决单库单表性能瓶颈(如查询延迟、写入吞吐不足)。 支持未来3-5年的业务增长(预估数据量、并发量)。 是否需要支持高可用、弹性扩...
面试题:MySQL 的存储引擎有哪些?它们之间有什么区别?
MySQL 的存储引擎是其核心功能之一,不同的存储引擎支持不同的特性、性能优化和适用场景。以下是常见的 MySQL 存储引擎及其区别: 一、常见存储引擎 InnoDB(默认引擎) 特点: 事务支持:支持 ...
面试题:MySQL 中 VARCHAR(100) 和 VARCHAR(10) 的区别是什么?
在 MySQL 中,VARCHAR(10) 和 VARCHAR(100) 是变长字符串类型,它们的主要区别在于最大字符长度限制和性能影响。以下是详细对比: 1. 存储长度限制 VARCHAR(10) 最多存储 10 个字符。 插入的数...
面试题:MySQL 中如果发生死锁应该如何解决?
在 MySQL 中,死锁是指两个或多个事务在等待对方释放资源,从而导致这些事务永远处于等待状态的情况。MySQL 的 InnoDB 存储引擎能够自动检测到死锁,并回滚其中一个事务来解决这个问题。 然而,...
面试题:MySQL 中 LIMIT 100000000, 10 和 LIMIT 10 的执行速度是否相同?
在 MySQL 中,LIMIT 100000000, 10 和 LIMIT 10 的执行速度 完全不同,且 LIMIT 10 明显更快。以下是详细分析: 1. 核心原因:偏移量(OFFSET)的处理 LIMIT 10 ...
面试题:请详细描述 MySQL 的 B+ 树中查询数据的全过程
MySQL 的 B+ 树 是 InnoDB 存储引擎实现索引的核心数据结构。查询数据的过程涉及从根节点逐层向下查找,最终在叶子节点定位目标数据。以下是基于 聚簇索引(主键索引) 和&...
面试题:什么是数据库的逻辑删除?数据库的物理删除和逻辑删除有什么区别?
逻辑删除与物理删除的概念 逻辑删除:指的是在数据库中不实际移除数据记录,而是通过标记的方式(如增加一个is_deleted字段,并将其值设为true或1)来表示该记录已被“删除”。这样做的好处是可...
面试题:什么是分库分表?分库分表有哪些类型(或策略)?
分库分表的定义 分库分表是一种数据库优化技术,用于解决单库单表性能瓶颈的问题。当数据量过大或并发访问压力过高时,将原本集中存储的数据分散到多个数据库或多个表中,从而提升数据库的性能...
面试题:详细描述一条 SQL 语句在 MySQL 中的执行过程。
一条 SQL 语句在 MySQL 中的执行过程涉及多个层次和组件的协同工作。以下是详细的执行流程,结合 MySQL 的架构(Server 层和存储引擎层)进行说明: 一、执行流程概览 客户端发送请求 连接管理...
