面试真实经历某商银行大厂数据库MYSQL问题和答案总结(一)

在 MySQL 的面试中,涉及数据库存储引擎、ACID 特性、隔离级别、索引等方面的问题是非常常见的。本文将逐一解答一些常见的 MySQL 面试问题,并提供详尽的解释。​编辑


1. 数据库存储引擎 MyISAM 和 InnoDB 的区别

MyISAMInnoDB 是 MySQL 中常见的两种存储引擎,它们在许多方面存在差异:

特性 MyISAM InnoDB
事务支持 不支持事务(非事务型) 支持事务(事务型)
锁机制 表锁 行锁
外键约束 不支持外键 支持外键约束
数据存储方式 每个表对应一个 .MYD 文件和 .MYI 文件 数据和索引都存储在同一个表空间中
崩溃恢复 无自动崩溃恢复机制 自动崩溃恢复机制
适用场景 适用于读取较多的场景 适用于事务处理较多的场景

总结 :InnoDB 是更现代、功能更强大的存储引擎,适用于需要事务、外键约束以及更高并发的场景。MyISAM 更适合只读或查询频繁的应用。​编辑


2. InnoDB 什么时候是行锁,什么时候是表锁

InnoDB 使用 行锁表锁 来处理并发。

  • 行锁 :当你执行 UPDATEDELETESELECT ... FOR UPDATE 等操作时,InnoDB 会锁定当前行以避免其他事务修改该行数据。行锁通常在进行单行操作时发生。
  • 表锁 :当执行 ALTER TABLELOCK TABLES 等操作时,InnoDB 会使用表锁,锁住整个表,阻止其他事务对该表进行操作。

总结:InnoDB 默认使用行锁,只有在必须锁住整个表时才使用表锁。


3. ACID 特性

ACID 是数据库事务的四大特性,确保事务的可靠性和一致性:

  • 原子性(Atomicity):事务中的操作要么全部完成,要么全部不完成,不会留下半成品。
  • 一致性(Consistency):事务必须使数据库从一个一致的状态转换到另一个一致的状态。
  • 隔离性(Isolation):一个事务的执行不应受到其他事务的影响,每个事务的中间状态对其他事务是不可见的。
  • 持久性(Durability):事务一旦提交,对数据库的修改是永久性的,即使系统崩溃也不会丢失。

4. 隔离级别

数据库的隔离级别定义了不同事务之间相互干扰的程度。MySQL 支持以下四种隔离级别:

  1. READ UNCOMMITTED(读取未提交):事务可以读取其他事务尚未提交的数据,容易产生脏读(Dirty Read)。
  2. READ COMMITTED(读取已提交):事务只能读取其他事务已提交的数据,避免了脏读,但可能会产生不可重复读(Non-repeatable Read)。
  3. REPEATABLE READ(可重复读):事务在整个执行过程中读取的数据是固定的,避免了脏读和不可重复读,但可能会产生幻读(Phantom Read)。
  4. SERIALIZABLE(可串行化):事务完全隔离,强制串行执行,避免了所有并发问题,但性能最低。

总结 :根据应用的需求和并发程度选择合适的隔离级别。一般来说,REPEATABLE READ 是 MySQL 默认的隔离级别。


5. 数据库删除数据需要的方法,哪种最快,快在哪里

删除数据有多种方法,常见的有:

  • DELETE :逐行删除,支持 WHERE 子句,可以回滚。
  • TRUNCATE:删除表中所有数据,但不删除表结构,不能回滚。

最快方法TRUNCATEDELETE 快,因为 TRUNCATE 不会逐行删除数据,而是直接删除数据页并重新分配内存。DELETE 会逐行删除,并产生大量的日志。


6. MySQL 怎么实现分页

MySQL 中分页通常使用 LIMITOFFSET 来实现:

sql 复制代码
SELECT * FROM table_name LIMIT 10 OFFSET 20;  

或者简写为:

sql 复制代码
SELECT * FROM table_name LIMIT 20, 10;  

这条 SQL 查询语句返回从第 21 条记录开始的 10 条记录。

总结LIMIT 用于限制返回的记录数,OFFSET 用于指定开始的位置。


7. 数据库有哪些数据类型? ​编辑

MySQL 支持多种数据类型,常见的有:

  • 数值类型INTFLOATDOUBLEDECIMAL 等。
  • 字符类型CHARVARCHARTEXTBLOB 等。
  • 日期和时间类型DATETIMEDATETIMETIMESTAMP 等。
  • 枚举和集合类型ENUMSET
  • 布尔类型BOOLEAN(MySQL 实际上存储为 TINYINT)。编辑

8. VARCHAR 和 CHAR 的区别

  • CHAR:定长字符串,存储时如果字符串长度不足,会用空格填充。适合存储固定长度的字段(如国家代码)。
  • VARCHAR:变长字符串,存储时根据实际长度存储,不会填充空格。适合存储可变长度的字段(如名字、地址等)。

总结VARCHAR 更节省存储空间,CHAR 在需要固定长度时更高效。​编辑


9. 数据库的索引有哪些?

常见的数据库索引类型有:

  • 主键索引(PRIMARY KEY):每个表只能有一个主键,主键列自动创建唯一索引。
  • 唯一索引(UNIQUE):保证字段的值唯一,但可以有空值(NULL)。
  • 普通索引(INDEX):没有唯一性约束,仅用于提高查询性能。
  • 全文索引(FULLTEXT):用于全文搜索,适用于文本数据。
  • 复合索引(Composite Index) :由多个列组成的索引。编辑

10. B+ 树索引的叶子结点放的是什么?

B+ 树索引 中,叶子结点存储的是实际的 数据指向数据的指针。B+ 树是一种平衡树结构,所有的叶子结点都在同一层,并且通常会按照某种顺序排列,方便高效的查找。

总结:B+ 树的叶子结点存储着关键字及对应的记录位置,而非叶子结点只存储关键字和指向下一层的指针。

​编辑---

总结

本篇文章涵盖了 MySQL 中一些常见的面试问题,从存储引擎到索引、ACID 特性等,帮助你了解 MySQL 数据库的基础知识和常见面试考点。掌握这些知识,能够在面试中应对相关问题并展示你的数据库管理能力。

相关推荐
IT_陈寒13 小时前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端
ServBay14 小时前
为什么说 MCP 是 2026 年开发者必须掌握的黄金协议?
后端·mcp
程序员夏洛14 小时前
Spring Boot 多模块项目中 IDEA 提示 Cannot resolve symbol 的一次排查记录
后端
子兮曰14 小时前
OpenMontage 深度解剖:你的 AI 编程助手,其实是个视频工作室
前端·后端·ai编程
子兮曰15 小时前
前端工具链的「Rust 化」:一场没有赢家的军备竞赛?
前端·后端·rust
爱勇宝16 小时前
从 Ctrl+CV 到 Enter:程序员正在失去什么
前端·后端·程序员
程序员天天困16 小时前
Loop Engineering 实战:/goal 命令让 AI 自己写完整项目
github
洛卡卡了16 小时前
我们在用 AI 写代码时,为什么建议要好好维护 AGENTS.md 呢?
面试·agent·claude
徐小夕16 小时前
我们开源了一款“框架无关”的思维导图编辑器,3分钟集成到任意系统
前端·javascript·github
PBitW16 小时前
GPT训练我的第三天,明白了应该咋说满分回答!😕😕😕
前端·javascript·面试