• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

几个MySQL高频面试题的解答

mysql 搞代码 4年前 (2022-01-09) 22次浏览 已收录 0个评论
文章目录[隐藏]

前言: 

在各类技术岗位面试中,似乎 MySQL 相关问题经常被问到。无论你面试开发岗位或运维岗位,总会问几道数据库问题。经常有小伙伴私信我,询问如何应对 MySQL 面试题。其实很多面试题都是大同小异的,提前做准备还是很有必要的。本篇文章简单说下几个常见的面试题,一起来学习下吧。

1.什么是关系型数据库?谈谈你对 MySQL 的认识。

这是一道基础题,考察面试者对数据库的了解程度,一般可以简单讲下自己的认知,有条理即可。比如:

关系型数据库是指采用了关系模型来组织数据的数据库,其以行和列的形式存储数据。关系型数据库最大的特点是支持事务。常见的关系型数据库有 MySQL、Oracle、SQLServer 等。MySQL 是当下最流行的开源数据库。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,使得很多公司都采用 MySQL 数据库以降低成本,目前被广泛地应用在 Internet 上的中小型网站中,尤其适用于 OLTP 领域。

2.MySQL 常见的存储引擎有哪些,有什么区别?

这个问题也经常被问到,和『InnoDB 与 MyISAM 引擎的区别』问题相似。

常见的几种存储引擎:

  • InnoDB: MySQL 默认的存储引擎,支持事务、MVCC、外键、行级锁和自增列。
  • MyISAM: 支持全文索引、压缩、空间函数、表级锁,不支持事务,插入速度快。
  • Memory: 数据都在内存中,数据的处理速度快,但是安全性不高。
  • ARCHIVE: 常用于历史归档表,占用空间小,数据不能更新删除。

InnoDB 与 MyISAM 引擎的几点区别:

  • InnoDB 支持事务,MyISAM 不支持事务。
  • InnoDB 支持外键,而 MyISAM 不支持。
  • InnoDB 不支持全文索引,而 MyISAM 支持。
  • InnoDB 是聚簇索引,MyISAM 是非聚簇索引。
  • InnoDB 不保存表的具体行数,而 MyISAM 用一个变量保存了整个表的行数。
  • 本文来源gao@dai!ma.com搞$代^码!网7

  • InnoDB 最小的锁粒度是行锁,MyISAM 最小的锁粒度是表锁。
  • 存储结构不同,MyISAM 表分为 frm MYD MYI 三个,InnoDB 一般分为 frm ibd 两个。

3.描述下 MySQL 基础架构。

这个问题考察面试者对 MySQL 架构的了解,和『一条 select 语句执行流程』问题相似。

MySQL的逻辑架构主要分为3层:

  • 第一层:对客户端的连接处理、安全认证、授权等,每个客户端连接都会在服务端拥有一个线程,每个连接发起的查询都会在对应的单独线程中执行。
  • 第二层:MySQL的核心服务功能层,包括查询解析、分析、查询缓存、内置函数、存储过程、触发器、视图等,select操作会先检查是否命中查询缓存,命中则直接返回缓存数据,否则解析查询并创建对应的解析树。
  • 第三层:存储引擎,负责数据的存储和提取,MySQL服务器通过API与存储引擎通信,屏蔽了各种引擎之间的差异,常见的存储引擎有:InnoDB、MyISAM。

一条 select 语句执行流程:

  • 客户端通过连接器与 MySQL 服务器建立连接,并获取了用户的读写权限,然后提交查询语句。
  • 首先 MySQL 会在查询缓存中对提交的语句进行查询,如果命中且用户对表有操作权限,会直接返回查询缓存中查询结果作为本次查询的结果,查询到此结束。
  • 如果查询缓存未命中,会来到分析器,分析器会解析语句并检查其合法性。如果语句不符合 MySQL 的语法规范,执行器会报错,查询到此结束。
  • 若语句合法,会来到优化器,优化器会为 SQL 语句选择最优的执行计划。
  • 最后来到执行器,如果用户对表有操作权限,执行器会调用存储引擎提供的接口来执行 SQL 语句,然后将查询结果返回给客户端,查询到此结束。

4.说说常用的几种字段类型。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:几个MySQL高频面试题的解答

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址