数据库-mysql-索引

思考维度

树越矮(节点存储的索引值越多),查越快

知识点

【MySQL】聚集索引和非聚集索引

刷题

为什么索引的数据结构不可以是红黑树?

因为数据量大,红黑树会很高,磁盘IO次数多

B树和B+树的区别?

1.B树的非叶子节点除了索引值,还有其他字段值;B+树的非叶子节点只有索引值

2.B+树的叶子节点是双向链表结构;B树的叶子节点之间没有联系

B+树查找某一个索引值的过程

将根节点(页 16k)load到内存,二分查找,如果找到就结束,找不到就继续load节点

高度为3的B+树大概能存储多少行记录?

一个非叶子节点大概能存储几个索引值:16KB/(8B+6B)=1170

一个叶子节点大概能存储几行记录:16KB/1KB=16

1170117016=2000W

为什么IndoDB存储引擎的索引数据结构不用B树?

B树的缺点:B树的非叶子节点也会存储数据,这样会让每个节点可以存储的索引值变少,树变高

存储引擎是表维度的,还是数据库维度的?

表维度的

因为在定义表结构的时候,可以选择存储引擎

MyIsam和IndoDB的区别?

MyIsam的数据和索引是分开存储的;InnoDB的数据和索引是存储在一个文件

MyIsam的叶子节点的数据存储的是记录的物理地址;InnoDB的叶子节点的数据存储的是记录(聚簇索引)

为什么建议InnoDB表要加主键?

如果不加主键,mysql会选一列(没有重复值的 如果全都有重复,则新增一个字段)作为主键

这种事情我们自己做就好了,不要交给mysql

为什么推荐整型自增主键?

整型:比较大小更快(B+树)

自增:乱序插入会引起B+树的分裂和合并,顺序插入只会新增节点

索引使用Hash表不可以么?

缺点:hash只有=和in操作快,其他都需要全表扫描

聚集索引和非聚集索引

聚集索引是InnoDB的;非聚集索引是MyIsam的

主键索引和二级索引

InnoDB:主键索引的叶子的值是主键,数据是记录;二级索引的叶子的值是非主键字段,数据是主键

为什么二级索引的叶子的数据是主键,而不是记录?

节省存储

一致性

为什么索引要满足最左前缀原则?

(a,b,c)

如果查询条件是where b = 1 and c = 2

只有在a相等的情况下,b才是有序的

相关推荐
小句9 分钟前
Kafka 中基于 Segment 和 Offset 查找消息的过程
数据库·分布式·kafka
geovindu36 分钟前
MVC(Model-View-Controller)framework using Python ,Tkinter and SQLite
数据库·sqlite·mvc
Nodejs_home1 小时前
TaskBuilder数据模型设计器使用简介
数据库·低代码·oracle
紅色彼岸花2 小时前
一、boolen盲注和时间盲注
数据库·安全性测试
小梁不秃捏3 小时前
SQL 大厂面试题目(由浅入深)
数据库·sql·面试
管理大亨3 小时前
C#+UDP接收数据,并将数据保存到redis,定时同步到数据库Sql Server中
数据库·udp·c#
新玉54014 小时前
DVWA靶场
android·java·数据库·php
苹果酱05676 小时前
细读 React | React Router 路由切换原理
java·vue.js·spring boot·mysql·课程设计
苏寅6 小时前
在 debian 12 上安装 mysqlclient 报错
linux·mysql·debian
yuanpan6 小时前
SQLite数据库中查询性能优化及索引创建的原则总结
数据库·性能优化·sqlite