夯实MySQL基础的问题归纳

本篇文章给大家带来了关于mysql的相关知识,其中主要总结了一些常见的问题,解决一下,包括了常规的,还有索引类、原理类和框架类的相关内容,希望对大家有帮助。 推荐学习:m

    本篇文章给大家带来了关于mysql的相关知识,其中主要总结了一些常见的问题,解决一下,包括了常规的,还有索引类、原理类和框架类的相关内容,希望对大家有帮助。

常规篇

1、说一下数据库的三大范式?

第一范式:字段原子性,第二范式:行唯一,有主键列,第三范式:每列和主键列都相关。

实际应用中会通过冗余少量字段来少关联表,提升查询效率。

2、只查询一条数据,但是也执行非常慢,原因一般有哪些?

聚集索引:聚集索引就是以主键创建的索引,聚集索引在叶子节点存储的是表中的数据。

非聚集索引:非主键创建的索引,在叶子节点存储的是主键和索引列,使用非聚集索引查询出数据时,拿到叶子上的主键再去查到想要查找的数据。(拿到主键再查找这个过程叫做回表)。

覆盖索引:假设所查询的列,刚好都是索引对应的列,不用再回表查,那么这个索引列就叫覆盖索引。

3、InnoDB 为什么设计B+树,而不是B-Tree,Hash,二叉树,红黑树?

背景:B+ 树提供的这个快速定位能力,来源于同一层兄弟节点的有序性,所以说破坏了这个有序性,大概率就失效了,具体有如下几种情况:

对索引使用左或者左右模糊匹配:也就是 like %xx 或者 like %xx% 这两种方式都会造成索引失效。原因在于查询的结果可能是「陈林、张林、周林」等之类的,所以不知道从哪个索引值开始比较,于是就只能通过全表扫描的方式来查询。

对索引使用函数/对索引进行表达式计算:因为索引保存的是索引字段的原始值,而不是经过函数计算后的值,自然就没办法走索引了。

对索引隐式类型转换:相当于用了新函数

WHERE 子句中的 OR:的含义就是两个只要满足一个即可,因此只有一个条件列是索引列是没有意义的,只要有条件列不是索引列,就会进行全表扫描。

方案篇

1、有一个未分库分表的系统,如何设计才可以让系统动态切换到分库分表上?

原理篇

1、一条 MySQL 语句执行步骤是什么样的?

框架篇

1、Mysql 主从复制原理的是啥?