面试真实经历某商银行大厂数据库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 数据库的基础知识和常见面试考点。掌握这些知识,能够在面试中应对相关问题并展示你的数据库管理能力。

相关推荐
我命由我123455 分钟前
Java 并发编程 - Delay(Delayed 概述、Delayed 实现、Delayed 使用、Delay 缓存实现、Delayed 延迟获取数据实现)
java·开发语言·后端·缓存·java-ee·intellij-idea·intellij idea
T___T1 小时前
全方位解释 JavaScript 执行机制(从底层到实战)
前端·面试
我是天龙_绍1 小时前
java 比对两对象大小 重写 comparator
后端
IT_陈寒1 小时前
Python 3.12新特性实测:10个让你的代码提速30%的隐藏技巧 🚀
前端·人工智能·后端
BingoGo1 小时前
从零开始打造 Laravel 扩展包:开发、测试到发布完整指南
后端·php
9号达人2 小时前
普通公司对账系统的现实困境与解决方案
java·后端·面试
golang学习记2 小时前
Go 1.26 新特性:netip.Prefix.Compare —— 标准化 IP 子网排序能力
后端
花落已飘2 小时前
openEuler容器化实践:从Docker入门到生产部署
后端
Cache技术分享2 小时前
233. Java 集合 - 遍历 Collection 中的元素
前端·后端