Mysql八股文--常问整理(小林coding精简版-自我总结)

1、什么是索引?

索引就是数据的目录,方便用户更加快捷的查找数据。

2.索引的分类

数据结构划分:B+、哈希、full-text索引

物理存储划分:主键索引、辅助索引

字段特性:主键索引、前缀索引、普通索引、唯一索引

字段个数:单列索引、联合索引。

3.为什么选择B+不选择B

因为B+只在叶子节点进行存放数据,但是B树会在节点存放 ,所以B+的单个节点的数据量更小,在相同Io下,查询的节点更多。

B+使用的是双向链表,适合作用于范围查找

4.为什么选择B+不选择二叉树

二叉树是一个节点只有俩个节点,会导致层数的楼层过高,增加Io读写的次数。

5.为什么选择B+不选hash

首先哈希他的取得时间复杂度是O(1),但是呢,哈希表只适合做等值查找,不可以做范围查找。

6.索引的优缺点,什么时候适用于,什么时候不适用

优点:加快读取速度,提高数据库的读取数据得能力。

缺点:消耗硬盘容量、维护索引的时间随着数据的上升成倍增长、在数据的增删改中需要花费更多的时间

适用于:经常查询where语句,有唯一字段、经常作用域order by 还有group by

不适用:频繁进行增改删的数据、字段中存在大量重复数据、表数据太少

7.优化索引的方法

前缀索引优化

覆盖索引优化

主键有序自增

防止索引失效

8.主键为什么最好是自增

因为在B+树中,数据会跟着主键有序存放,如果是自增,就不需要查找,只要通过追加即可,但是由于不是有序,我需要分裂表,分裂表就很容易产生空间碎片。

9.为什么索引最好是notNULL

处理NULL需要进行单独处理,增加处理时间;null会有null字段标志,会浪费一个字节的空间。

10.索引失效的原因

使用了like %abc,或者是使用了like %abc%

索引应该使用最左原则,左边的优先级要大于右边的

使用or语句的时候,左边使用了索引,而右边没有

在索引字段进行计算、函数、类型转换

11.扫描的类型分为哪些

ALL(全表扫描)

index(索引扫描)

range(索引范围扫描)

ref(非唯一索引扫描)

eq_ref(唯一索引扫描)---一般只出现在联合索引之中

const(常量级)

12.优化索引的方法

1.覆盖索引

2.前缀索引

3主键自增

4索引为 not null

相关推荐
2401_8504916521 分钟前
安装宝塔面板提示端口被占用_查找并终止占用进程
jvm·数据库·python
2401_8330336222 分钟前
如何通过Java存储过程执行OS命令_Runtime.getRuntime().exec的封装与安全限制
jvm·数据库·python
weixin_4597539422 分钟前
SymPy中正确处理含整数参数的三角函数定积分:避免n=0特例干扰结果
jvm·数据库·python
李少兄29 分钟前
领域驱动设计与 Clean Code 的实践
java·数据库·领域驱动
Mr. zhihao32 分钟前
[特殊字符] 从 Redis 缓存穿透到布隆过滤器,再到布谷鸟过滤器:一次穿透防护的进化之旅
数据库·redis·缓存
@小匠37 分钟前
Redis 7 持久化机制
数据库·redis·缓存
Geoffwo43 分钟前
Oracle MySQL8.0升级8.4,无感升级数据库
数据库·oracle
u01102251244 分钟前
如何自定义查询历史记录面板的展示风格_时间轴样式设计
jvm·数据库·python
2301_769340671 小时前
HTML怎么实现快捷跳转顶部_HTML固定悬浮锚点按钮【介绍】
jvm·数据库·python
m0_609160491 小时前
MySQL如何限制触发器递归调用的深度_防止触发器死循环方法
jvm·数据库·python