java面试一日一题:mysql中常用的存储引擎有哪些?
问题:请讲下mysql中常用的引擎有哪些?
分析:该问题主要考察对mysql存储引擎的理解,及区别是什么?
回答要点:
主要从以下几点去考虑,
1、mysql的存储引擎的基本概念?
2、mysql中常用的存储引擎有哪些及各自的区别是什么?
从上篇《java面试一日一题:请讲下对mysql的理解》已经知道了mysql从整体架构上分为两部分,一部分是server层,另外一部分是存储引擎层。说的简单点存储引擎就是用来实际管理mysql中的数据,为了适用于不同的场景有了不同的存储引擎。比较常用的存储引擎有myIsam和Innodb两种。
myIsam
myIsam不支持事务;
myIsam不支持外键;
myIsam的索引是非聚集索引,索引和数据是分开的;
myIsam使用一个变量保存了表中的数据总行数
myIsam支持表锁;
myIsam支持全文索引;
Innodb
innodb支持事务,事务的实现依靠redo log、undo log、锁、MVCC等技术;
inndo是聚集索引,主键索引和数据是在一起的;
innod没有保存数据的总行数;
innodb支持表、行锁,默认是行锁;
innodb不支持全文索引,在5.7以后的版本才支持全文索引;
本文简单的从一个面试过程中常见的面试题入手,讲解了mysql的myIsam和Innodb两种存储引擎的区别。其实从上面的回答中面试官可以引申出很多问题,例如,
1、什么是聚集、非聚集索引;
2、mysql的索引数据结构是什么样子的,为什么使用B+树;
3、什么是redo log、undo log
4、什么是MVCC;
5、事务的特性有哪些;
简单列举下由本题引申的面试点,后面会统一总结。
感谢分享、关注、收藏。公众号:【良工说技术】
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)