Mysql面试题总结

1. 背景

mysql作为最常用的中间件,还是有很多地方指导费学习的,看这些面试题是要理解的去记忆,然后看看mysql相关的书籍,就可以触类旁通了

2. 面试题

2.1 mysql 高度为3的b+ 树能存储多少数据

索引页存放的是索引值 + 指针,mysql 设计者为了避免每条数据都从磁盘进行读取,设计了页结构 用于磁盘和内存之间的交互,分为索引页和数据页
一个页16KB,磁盘存储数据的最小单元是扇区,扇区512byte ,B+ 树的每个节点只有一个页么
高度为2的时候。一个根节点和若干个叶子节点,根节点的指针数 * 单个叶子结点的记录数就是存储的数据量,假设表单 主键id,bigint占用8byte,指针在mysql中6byte, 一个索引页用16 * 1024、 14 = 1170.索引页有1170个索引记录,假设一行数据1KB,一个页就是16行数据,1170 * 16 = 18720行记录
三层B+ 树, 1170 * 1170 * 16 得到千万级的数据,进行1到3次的IO就可以获取

2.2 update 语句是锁表还是锁行

where 命中索引就是锁行,否则锁表
测试语句

sql 复制代码
set  @@autocommit = 0;

select @@autocommit;

update user set name = 'dyw11' where age = 40;

commit;

alter table user add index idx_age(age)

2.3 mysql 表设计时间列用datetime还是timestamp

相关推荐
迷渡20 分钟前
聊一聊 Bun 用 Rust 重写这件事
开发语言·后端·rust
王中阳Go24 分钟前
秒杀、分库分表、全链路追踪:一个电商微服务的架构全拆解
后端·go
正儿八经的少年31 分钟前
Spring Boot 两种激活配置方式的作用与区别
java·spring boot·后端
回家路上绕了弯1 小时前
AgentScope Java实战博客:从入门到落地,解锁智能代理开发新范式
后端
疯狂成瘾者1 小时前
Spring Boot 项目中的 SMTP 邮件验证码服务技术解析
java·spring boot·后端
阿苟1 小时前
消息队列重点详解
后端·面试
RustCoder1 小时前
MangoFetch:一个用 Rust 写的 CLI/TUI 高性能的下载工具
后端·rust·开源
程序员清风1 小时前
AI开发岗该如何准备面试?
java·后端·面试
折哥的程序人生 · 物流技术专研2 小时前
《Java 100 天进阶之路》第20篇:Java初始化、构造器、对象创建的过程
java·开发语言·后端·面试
Lee川2 小时前
从输入框到智能匹配:一文读懂搜索功能的完整实现
前端·后端