MySQL 简记

news/2025/3/21 7:05:53/

MySQL 简记

mysql中的数据存储的结构是B+树

  • 其与B树的相同点是,B+树一个节点也可以存放多条数据,并且从左到右依次增大;
  • 不同点是,B+树的叶子结点之间也能相互连接。那么实际上是采取利用空间换区时间的策略。

那么B+树的树结构like this:

请添加图片描述

然后mysql中的数据存储是这样的:

其实在mysql里面自增主键是要比uuid要好的,原因是因为,当每次插入数据的时候,直接向下、向下一页去插入就好了;如果说不是自增主键,那么当一页数据存满,新插入的数据主键大小应该是在旧的页上时,就需要挪动原始的旧数据的最后一个,插入到新的一页,然后将新插入的数据插入到旧的也里面中,这伴随着系统的消耗。

可以回答为什么innodb中使用B+树来存储,用空间换时间

在这里插入图片描述
在这里插入图片描述

就是用空间换取时间的效率,假设一页能存四条数据,那么每一个页都有一个页目录,页目录存的是主键的索引,每隔几个一个索引,在利用索引查找的时候,先查找页目录,就能快速遍历一页的数据,倘若目标主键在这一页的某两个主键索引之中,再从页目录那个对应的索引所给的地址跑到用户数据区域毒地赢得数据,再从中间开始遍历数据区域,直到找到目标数据。这个时候已经离目标很近的,就很快能走完。

当有很多很多页的时候,就有一个头页,当有很多很多头页,就有一个更高的头页来建立索引。因此当查询一个很大的索引例如600000时,不需要从头数据遍历到尾,只需要遍历最头的页就清楚了。

注:超级页就是头页,一般两层的B+树就好了

innodb是如何支持范围查找能走索引的?

索引的时候,如果范围查找select * from table1 where a = 6;,假设a是主键,那么走的是主键索引,从头页开始从上往下找;如果我搜索的不是主键,而是b= 6,那么就是全表扫描,走的是最下面这一层的页,一页一页的走查找b.

innodb里面的一页是多大?

数据库中,一页是16dkB,计算机操作系统里面一页时4KB大小。

那么高度为2的B+树能存多少条数据?

一条数据是包含一个int值和一个指针,那么就是4B+6B = 10B,一个头页里面能存A=16KB/10B个页,然后一个页里面用B=16KB/一条数据,最后存的数据量就是A*B。

为什么遵循最左前缀原则才能利用索引?

因为创建索引的时候,假如有5个字段,第一个为主键,创建中间的三个为一个复合索引,这个其实也就是非聚族索引的一种,它会构建一个B+树,那么树的排列,数值的分布都是按照:比较第一个字段,如果第一个字段相同再比较第二个字段,其次再比较第三个字段的形式进行构建树的,所以必须要遵循最左前缀原则才能利用索引。那么找到了对应的索引之后会进行回表查询全字段的值。如何能够回表到对应的数据?是索引里面存了主键的值,那么通过主键就可以回表找到信息返回

覆盖索引和索引扫描的底层原理

覆盖索引就是,复合索引里面包含了要查找的字段,那么这个时候就不用回表查看全字段数据,直接走索引找到需要的索引的字段就好了。

索引扫描是,相比全表扫描,索引扫描里包含了要查找的对应的字段,那么一页里面包含的数据就会更多,查找的就会更快,所以这个时候,用索引反而更快一些。

mysql_51">mysql里面类型转换需要注意的

一般是char型的会转换为int型的,它会直接把字符转换为数字0

所以explain select * from table1 where a = 0,如果a是一个int类型的字段,而数据里面有个字符‘c’的话,那么会查找到它,‘c’->0

那么如果是a字段里面存了字符’1’,那么会直接转成数字’1’

什么情况下会导致索引失效

当直接对字段进行操作,比方说搜索a+1 =1这样的情况,那么对于数据库引擎来说,都要先对内存里面的构造的索引B+树进行更改,例如字段类型是varchar的,对他加了1,那么需要先把所有的字段全部都转换成数字(字符字母转换成0,数字‘1’转换成1),然后再加上1,然后再进行索引查找。这以过程耗费的资源是很大的,

而且还可能会引发问题,可能会破坏B+树的顺序。

那么:一旦对字段进行了操作,那就会导致索引失效,走不了索引

mysql_69">mysql慢查询如何优化

  1. 检查是否走了索引,如果没有则优化其利用索引
  2. 检查所以利用的索引,是否是最优索引
  3. 检查所查字段是否都是必须的,是否查询了过多字段,或者多余数据
  4. 检查表中数据是否过多
    索引
  5. 检查所以利用的索引,是否是最优索引
  6. 检查所查字段是否都是必须的,是否查询了过多字段,或者多余数据
  7. 检查表中数据是否过多
  8. 检查数据库实例所在机器的性能配置,

http://www.ppmy.cn/news/1580804.html

相关文章

【Linux———生产消费模型】

并不是真的路过而已,也不是真的不会想你.............................................................................. 文章目录 前言 一、【生产者消费者模型的介绍】 1、【概念引入】 2、【特点—321原则】 3、【优点】 二、【基于阻塞队列的生产者消费…

第八:在Go语言项目中使用Zap日志库

介绍 在许多Go语言项目中,我们需要一个好的日志记录器能够提供下面这些功能: 能够将事件记录到文件中,而不是应用程序控制台。日志切割-能够根据文件大小、时间或间隔等来切割日志文件。支持不同的日志级别。例如INFO,DEBUG&…

涨薪技术|Kubernetes(k8s)之Namespaces详解

今天我们学习k8s另外一个必须要掌握的知识:Namespaces 01Namespaces基本操作 Namespaces表示名字空间,用于分隔资源存储资源,创建多个虚拟集群。 当团队或项目中具有许多用户时,可以考虑使用Namespace来区分,a如果是少…

Java:Apache HttpClient中HttpRoute用法的介绍

当使用Apache HttpClient组件时,经常会用到它的连接池组件。典型的代码如下: PoolingHttpClientConnectionManager connectionManager new PoolingHttpClientConnectionManager();connectionManager.setMaxTotal(httpConfig.getMaxPoolTotal());connect…

【微信小程序变通实现DeepSeek支持语音】

微信小程序实现录音转文字,并调用后端服务(Node.js)进行语音识别和,然后调用DeepSeek 处理的完整实现。 整体架构 前端(微信小程序): 实现录音功能。将录音文件上传到后端。接收后端返回的语音…

STC89C52单片机学习——第28节: [12-2] AT24C02数据存储秒表(定时器扫描按键数码管)

写这个文章是用来学习的,记录一下我的学习过程。希望我能一直坚持下去,我只是一个小白,只是想好好学习,我知道这会很难,但我还是想去做! 本文写于:2025.03.20 51单片机学习——第28节: [12-2] AT24C02数据存储&秒表(定时器扫…

亚马逊Prime Day新算法曝光,2025年流量分配机制大调整

亚马逊Prime Day新算法曝光,2025年流量分配机制大调整 亚马逊调整流量分配规则,影响卖家竞争格局 近日,亚马逊内部泄露的一份文件引发了全球跨境电商卖家的广泛关注。据悉,这份文件披露了亚马逊即将在2025年Prime Day正式启用的新…

DRAMiTransformer:空间与通道注意力融合的高效视觉变换块

DRAMiTransformer:空间与通道注意力融合的高效视觉变换块 随着深度学习在计算机视觉领域的快速发展,自注意力机制(Self-Attention)逐渐成为各种任务的核心组件。然而,传统自注意力机制往往需要较高的计算成本&#xf…