千家信息网

面试必备的10道MySQL题

发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,MySQL 事务,是我们去面试中高级开发经常会被问到的问题,很多人虽然经常使用 MySQL,SQL 语句也写得很溜,但是面试的时候,被问到这些问题,总是不知从何说起。下面我们先来了解一下什么是 MyS
千家信息网最后更新 2025年11月07日面试必备的10道MySQL题

MySQL 事务,是我们去面试中高级开发经常会被问到的问题,很多人虽然经常使用 MySQL,SQL 语句也写得很溜,但是面试的时候,被问到这些问题,总是不知从何说起。下面我们先来了解一下什么是 MySQL事务,再给大家分享10道面试必备的MySQL题。

MySQL事务是数据处理的最小操作单元,是一组不可在分割的操作集合,这个操作单元里的一系列操作要么都成功,要么都失败。

1、MySQL主从复制的原理。
(1)、主库必须开启二进制日志
(2)、当有增删改的语句时,会记录到主库的binlog中
(3)、主库通过IO线程把binlog里面的内容传给从库的relay binlog(中继日志)(这是msyql复制是异步复制的原因)
(4)、从库的sql线程负责读取它的relay log里的信息并应用到数据库中
2、Seconds_Behind_Master的原理。
表示sql线程和io线程之间的时间差
具体的计算:从库服务器当前的时间戳与二进制日志中的事件的时间戳相对比得到的,所以只有在执行事件时才能报告延迟。
不足:
一些错误(例如主备的max_allowed_packet不匹配,或者网络不稳定)可能中断复制,由于主从复制是异步操作,Seconds_Behind_Master可能显示为0
3、主从延迟的主要原因有哪些?
(1)、慢SQL语句过多
(2)、从库的硬件比主库差
(3)、同一个主库下有过多的从库
(4)、网络延迟
(5)、表分区过多
(还有一些原因,欢迎补充)
4、MySQL常见存储引擎及各自特点。
(1)、InnoDB
支持事务、行级锁、支持外键约束,主要面向OLTP的应用,使用next-key locking 的策略来避免幻读现象的产生.
(2)、MyISAM
不支持事务、表锁设计、支持全文索引、读写互相阻塞、不支持外键约束;主要面向OLAP应用场景;缓存池只缓存索引文件,不缓存数据文件
(3)、Memory
将所有数据保存在RAM中,在需要快速查找引用和其他类似数据的环境下,可提供极快的访问。如果数据库重启或者奔溃,数据都将丢失。
(4)、TokuDB
支持事务、高压缩、告诉读写、基于稀疏树索引设计;支持大多数在线修改索引、添加字段。
(5)、Inforbright/infinidb
列式存储、高压缩、单列查询快
5、innodb_flush_log_at_trx_commit参数0、1和2分别代表什么?
innodb_flush_log_at_trx_commit参数可以控制将redo log buffer中的更新记录写入到日志文件以及日志文件刷新到磁盘的操作时机。
0
每秒一次触发log buffer写入log file中,并且log file刷新到磁盘。
(由于进程调度问题,不能保证每秒100%刷新;如果mysql进程崩溃,可能会丢失1s的事务;效率最高,但最不安全)
1
每次事务提交触发log buffer写入log file中,并且log file刷新到磁盘。
2
每次事务提交,log buffer写入log file中;每秒log file刷新到磁盘。
(如果操作系统崩溃或者停电,可能会丢失1s的事务)
6、Mysql中varchar和char的区别
CHAR列的长度固定为创建表时声明的长度,范围(0-255)
VARCHAR列的长度不固定,范围(0-65535)
7、varchar(50)中的50代表的含义、int(20)中20的含义。
varchar(50)中的50代表最多能存放50个字符
int(20)中20的含义表示显示宽度,跟着zerofill一起才有意义
8、MySQL binlog的几种日志录入格式的涵义、适用场景和在复制中的优劣。
(1)、statement level模式
每一条会修改数据的sql都会记录到master的binlog中,slave在复制时sql进程会解析成和原来master端执行过的相同的sql再次执行。
适用场景:对主从数据一致性要求不太高,并且很少用到函数、存储过程、触发器等场景
优点:bin-log日志量少
缺点:部分新功能(函数、存储过程、触发器)同步会有障碍,比如now()
(2)、row level模式
日志中会记录成每一行数据被修改的形式,然后再slave端再对相同的数据进行修改
适用场景:对主从数据一致性要求比较高的场景。
优点:记录的详细
缺点:binlog日志量过大
(3)、mixed模式
MySQL默认采用statement格式进行二进制日志文件的记录,但是在一些情况下会使用row格式,可能的情况有:
1)、表的存储引擎为NDB,此时对表的DML操作都会以ROW格式记录
2)、使用了UUID(),USER(),CURRENT_USER(),FOUND_ROWS(),ROW_count()等不确定函数时
3)、使用了insert delay语句
4)、使用了用户定义函数(UDF)
5)、使用了临时表
适用场景:对主从数据一致性要求不太高,可能会用到函数、存储过程、触发器等场景
优缺点介于statement和row模式之间
9、重做日志和二进制日志的区别(至少三点)
(1)涉及存储引擎不一样:
binlog记录的是所有存储引擎的操作记录
redo log只记录innodb存储引擎的日志
(2)记录内容不一样:
binlog记录的是关于一个事务的具体操作内容。为逻辑日志
而redo log记录的是每个页更改的物理情况
(3)写的时间不一样:
binlog文件仅在事务提交前进行提交,即只写磁盘一次
而在事务进行过程中,却不断有重做日志条目被写入到重做日志文件中。
10、Explain执行计划中要关注哪些要素?
(1)、type:本次查询表联接类型,从这里可以看到本次查询大概的效率
(2)、key:最终选择的索引,如果没有索引的话,本次查询效率通常很差
(3)、key_len:本次查询用于结果过滤的索引实际长度
(4)、rows:预计需要扫描的记录数,预计需要扫描的记录数越小越好
(5)、extra:额外附加信息,主要确认是否出现 Using filesort、Using temporary 类似情况

以上10道MySQL面试题,只是众多MySQL面试题中的部分,个人认为是比较典型的,出现频率也比较高的试题,希望对你们有帮助!

日志 事务 数据 存储 场景 文件 索引 支持 主从 函数 引擎 磁盘 查询 二进制 情况 时间 格式 模式 线程 语句 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 武汉网盾网络安全有限公司 服务器只开放80端口怎么映射 应用软件开发属于现代服务业吗 工信部网络安全管理系统 什么是网络安全日活动 小学学校网络安全防范措施 数据库中数据字典 苹果更换号码显示连接服务器失败 数据库关于窗体作文 域名和服务器进不去网站怎么办 炸服务器的狗狗 服务器硬盘空间管理 用户会员怎么规划数据库 集团公司软件开发 宝山区网络软件开发不二之选 课题吧数据库 p2p网络技术的应用 统计局要求企业填的数据库 系统数据库更新时间 雇佣兵行动怎么创建服务器 试论述数据库的二级映像技术 当地运营商服务器管理优势 天津通信软件开发参考价格 金盾6942服务器机柜 加强网络安全顶层设计 数据库宏命令奇数 厦门银行软件开发中心待遇 魔兽怀旧服怎么解除服务器关联 奇异果园app软件开发 奥鹏软件开发有限公司
0