MySQL 简记

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里面类型转换需要注意的

一般是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慢查询如何优化

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/898510.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

十七、实战开发 uni-app x 项目(仿京东)- 后端指南

前面我们已经用uniappx进行了前端实战学习 一、实战 开发uni-app x项目(仿京东)-规划-CSDN博客 二、实战 开发uni-app x项目(仿京东)-项目搭建-CSDN博客 三、实战开发 uni-app x 项目(仿京东)- 技术选型-CSDN博客 四、实战开发 uni-app x 项目(仿京东)- 页面设计-C…

Infura 简介

文章目录 Infura 简介Infura 的主要功能Infura 的替代方案(类似服务)AlchemyQuickNodeAnkrMoralisPocket Network 什么时候选择 Infura? Infura 简介 Infura 是一个 区块链基础设施即服务(BaaS, Blockchain as a Service&#xf…

TouchSocket TcpService:构建高性能Tcp服务的终极利器

这里写目录标题 TouchSocket TCPService:构建高性能TCP服务的终极利器引言TCPService核心特性快速入门:5分钟搭建TCP服务1. 创建基础TCP服务2. 自定义插件处理数据 高级用法实战1. 客户端连接管理 性能与稳定性保障示例与源码结语 TouchSocket TCPServic…

Android Fresco 框架缓存模块源码深度剖析(二)

一、引言 在 Android 应用开发中,图片加载和处理是常见且重要的功能。频繁的图片加载不仅会消耗大量的网络流量,还会影响应用的性能和响应速度。因此,有效的缓存机制对于提升图片加载效率和用户体验至关重要。Fresco 是 Facebook 开源的一款…

springboot使用163发送自定义html格式的邮件

springboot使用163发送html格式的邮件 效果: 下面直接开始教学 注册邮箱,生成授权码 获取163邮箱的授权码,可以按照以下步骤操作: 登录163邮箱 打开浏览器,访问 163邮箱登录页面。 使用你的邮箱账号和密码登录。进入邮箱设置 登…

【Kafka】深入了解Kafka

集群的成员关系 Kafka使用Zookeeper维护集群的成员信息。 每一个broker都有一个唯一的标识,这个标识可以在配置文件中指定,也可以自动生成。当broker在启动时通过创建Zookeeper的临时节点把自己的ID注册到Zookeeper中。broker、控制器和其他一些动态系…

C#使用SnsPictureBox.dll绘制点,线段、圆、折线、多边形、测量尺等多种图形。

CSDN下载地址:https://download.csdn.net/download/sns1991sns/87726867 gitee下载地址:https://gitee.com/linsns/SnsPictrueBox 支持2种绘制方式:响应式和等待式。 一、使用响应式绘制图形 1、在窗口构造函数里添加绘制图形的完成响应函数 public…

Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!)

Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!) 在实战中,⼤多数情况下都不需要从0开始训练模型,⽽是使⽤“⼤⼚”或者其他研究者开源的已经训练好的⼤模型。 在各种⼤模型开源库中,最…

Redis BitMap 用户签到

Redis Bitmap Bitmap(位图)是 Redis 提供的一种用于处理二进制位(bit)的特殊数据结构,它基于 String 类型,每个 bit 代表一个布尔值(0 或 1),可以用于存储大规模的二值状…

Spring Boot 3 新特性实战:从理论到实践

引言 Spring Boot 自发布以来,凭借其简洁的配置和强大的功能,迅速成为 Java 开发者的首选框架。随着 Spring Boot 3 的发布,开发者们迎来了更多令人兴奋的新特性。本文将深入探讨 Spring Boot 3 的新特性,并通过实战示例展示如何…

Nodejs使用redis

框架:koa,通过koa-generator创建 redis: 本地搭建,使用默认帐号,安装说明地址以及默认启动设置:https://redis.io/docs/latest/operate/oss_and_stack/install/install-redis/install-redis-on-linux/ 中间件&#x…

调研报告:Hadoop 3.x Ozone 全景解析

Ozone 是 Hadoop 的分布式对象存储系统,具有易扩展和冗余存储的特点。 Ozone 不仅能存储数十亿个不同大小的对象,还支持在容器化环境(比如 Kubernetes)中运行。 Apache Spark、Hive 和 YARN 等应用无需任何修改即可使用 Ozone。Ozone 提供了 Java API、S3 接口和命令行接口…

AI学习——卷积神经网络(CNN)入门

作为人类,我们天生擅长“看”东西:一眼就能认出猫狗、分辨红绿灯、读懂朋友的表情……但计算机的“眼睛”最初是一片空白。直到卷积神经网络(CNN)​的出现,计算机才真正开始理解图像。今天,我们就用最通俗的…

除自身以外数组的乘积——面试经典150题(力扣)

题目 给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法,且在 O(n) 时…

⭐算法OJ⭐二叉树的前序遍历【树的遍历】(C++实现)Binary Tree Preorder Traversal

⭐算法OJ⭐二叉树的中序遍历【树的遍历】(C实现)Binary Tree Inorder Traversal Given the root of a binary tree, return the preorder traversal of its nodes’ values. Example 1: Input: root [1,null,2,3] Output: [1,2,3]Explanation: Exam…

计算机二级MS之Excel

声明:跟着大猫和小黑学习随便记下一些笔记供大家参考,二级考试之前将持续更新,希望大家二级都能轻轻松松过啦,过了二级的大神也可以在评论区留言给点建议,感谢大家!! 文章目录 考题难点&#x…

【Linux】VMware Workstation Pro 17 安装教程

目录 安装 VMware Workstation Pro 17 一、CDS Repository 获取安装包 二、网盘获取安装包 三、Broadcom官方获取安装包 后续安装过程没啥特殊要求 安装 VMware Workstation Pro 17 目前VMware Workstation pro 17已经对个人用户免费开放使用。 Broadcom官网地址&#x…

如何在云端平台上建立 30,000 名用户的网页 MMO游戏环境-2 (服务器)

接续上一篇「如何在云端平台上建立 30,000 名用户的网页 MMO游戏环境」,接下来讨论模拟连结上的问题。 最初计划使用35台伺服器来完成这个实验,希望能够有大量的用户连接,以验证真实的连接状况。然而,我们高估了这方面&#xff0c…

架构设计的灵魂交响曲:系统设计各维度的深度解析与实战指南

引言: 系统设计的背景与重要性 在快速变化的技术环境中,数字化转型成为企业生存与发展的核心驱动力。系统设计能力不仅是技术团队的核心竞争力,也是推动业务创新和提升整体效率的关键因素。根据Gartner的研究,超过70%的数字化转型项目未能实…

C语言指针(详细总结)

目录 1.初始C指针 几个重要的概念: 指针的加减 &与* 二级指针 2.指针与数组 指针数组 数组指针变量 一维数组与二维数组传参的本质 ​编辑​编辑 ​编辑 3.指针与函数 函数指针数组 4.指针与结构体 5.野指针以及常见的内存管理错误 常见的内存错…