排序
面试题:为什么 MySQL 索引用的是 B+ 树而不是红黑树?
MySQL 选择 B+ 树作为索引结构而不是红黑树,主要基于以下几个关键原因: 1. 磁盘 I/O 效率 B+ 树是为磁盘存储系统优化的数据结构: 多路平衡查找树:B+ 树的每个节点可以包含多个键值(通常为...
面试题:MySQL 中 InnoDB 存储引擎与 MyISAM 存储引擎的区别是什么?
MySQL中的InnoDB和MyISAM是两种常用的存储引擎,它们各自具有不同的特点和适用场景。以下是这两种存储引擎的主要区别: 事务支持 InnoDB:支持事务处理(ACID兼容),提供提交、回滚和崩溃恢复...
面试题:你们生产环境的 MySQL 中使用了什么事务隔离级别?为什么?
在生产环境中选择MySQL的事务隔离级别主要取决于应用的具体需求,包括数据一致性、并发性能以及可能出现的并发问题(如脏读、不可重复读和幻读)。 MySQL支持四种标准的事务隔离级别:READ UNCO...
面试题:MySQL 插入一条 SQL 语句,redo log 记录的是什么?
当 MySQL 执行一条插入(INSERT)SQL 语句时,redo log(重做日志)记录的是物理层面的页修改,而不是 SQL 语句本身。具体来说: 1. redo log 记录的内容 redo log 主要记录以下信息: 被修改的...
面试题:MySQL 中 TEXT 类型最大可以存储多长的文本?
在 MySQL 中,TEXT 类型用于存储大文本数据,其最大存储长度取决于具体的子类型。以下是详细的分类和存储容量: 1. TEXT 类型的分类与存储容量 类型最大字节长度典型场景TINYTEXT255 字节...
面试题:MySQL 的覆盖索引是什么?
MySQL 的覆盖索引是什么? 覆盖索引(Covering Index) 是 MySQL 中一种优化技术,指查询所需的所有字段都包含在某个索引中,使得 MySQL 可以直接通过索引获取数据,而无需回表查询实际的...
面试题:MySQL 中的回表是什么?
MySQL 中的回表是什么? 核心概念 回表 是 MySQL 中一种与索引查询相关的性能现象,通常发生在使用 二级索引(非聚簇索引) 进行查询时。 定义:当通过二级索引查询数据时,由于...
面试题:在 MySQL 中,你使用过哪些函数?
作为开发者,我在 MySQL 中经常使用以下各类函数: 一、字符串函数 基础处理函数: CONCAT(str1, str2,...) - 字符串连接 SUBSTRING(str, pos, len) - 提取子串 TRIM([BOTH|LEADING|TRAILING]...
面试题:对数据库进行分库分表可能会引发哪些问题?
分库分表是应对高并发、大数据量场景的常见优化手段,但也会引入一系列复杂问题。以下是主要问题及其分析: 1. 数据一致性问题 跨分片事务难题分库分表后,一个业务操作可能涉及多个分片(如扣...
面试题:什么是 MySQL 的主从同步机制?它是如何实现的?
MySQL 的主从同步机制是一种数据库复制技术,用于将主数据库(Master)上的数据变更实时或近实时地同步到一个或多个从数据库(Slave),从而实现高可用性、读写分离、数据备份等目标。以下是其...