泰安集团网站建设流程/唯尚广告联盟

泰安集团网站建设流程,唯尚广告联盟,许昌网站建设,企业内网网站MySQL 简记 mysql中的数据存储的结构是B树 其与B树的相同点是,B树一个节点也可以存放多条数据,并且从左到右依次增大;不同点是,B树的叶子结点之间也能相互连接。那么实际上是采取利用空间换区时间的策略。 那么B树的树结构like…

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,一经查实,立即删除!

相关文章

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

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

【Kafka】深入了解Kafka

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

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

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

Redis BitMap 用户签到

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

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)​的出现,计算机才真正开始理解图像。今天,我们就用最通俗的…

⭐算法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.野指针以及常见的内存管理错误 常见的内存错…

介绍一下TiDB、RocksDb、levelDB、LSM 树、SSTable。

LSM 树(Log-Structured Merge-Tree) 核心原理:通过将随机写转换为顺序写优化写入性能,适用于写密集型场景。数据首先写入内存中的 MemTable(有序结构,如跳表),当达到阈值后转为 Imm…

ESP32 BLE 初步学习笔记

前言 蓝牙作为一个庞大的知识体系,其学习和运用对于初学者来说显得有些复杂且凌乱。我整理了这段时间的学习笔记,涵盖了协议栈、工作流程、参数等内容。在实际应用中,我们主要使用 GAP 和 GATT,协议栈中的其他部分只需了解即可。…

代码随想录算法训练营第五十二天 |101. 孤岛的总面积102. 沉没孤岛103. 水流问题104.建造最大岛屿

101. 孤岛的总面积 卡码网:101. 孤岛的总面积(opens new window) 题目描述 给定一个由 1(陆地)和 0(水)组成的矩阵,岛屿指的是由水平或垂直方向上相邻的陆地单元格组成的区域,且完全被水域单…

Simple-BEV的bilinear_sample 作为view_transformer的解析,核心是3D-2D关联点生成

文件路径models/view_transformers 父类 是class BiLinearSample(nn.Module)基于https://github.com/aharley/simple_bev。 函数解析 函数bev_coord_to_feature_coord的功能 将鸟瞰图3D坐标通过多相机(针孔/鱼眼)内外参投影到图像特征平面&#xff0…

A/B测试入门指南

目录 一、什么是A/B测试1.1 A/A测试1.2 多变量测试 二、A/B测试应用场景三、A/B测试基本流程四、A/B测试面试真题4.1 【是什么】4.2 【为什么】4.3 【怎么做】 五、应用实战 一、什么是A/B测试 A/B 测试是一种常见的实验方法,用于比较两个或多个方案的效果&#xff…

自己构建的交叉编译器找不到PATH_MAX

接上篇centos6.10 编译gcc11.5 x64到aarch64交叉工具链 -CSDN博客 PATH_MAX找不到,不仅在编译gcc的过程中遇到,而且临时改gcc源码添加#define PATH_MAX 4096 宏定义后勉强通过gcc全量编译。这个新的gcc编译使用了PATH_MAX宏的代码还是会找不到。这个问题…

vscode查看文件历史git commit记录

方案一:GitLens 在vscode扩展商店下载GitLens 选中要查看的文件,vscode界面右上角点击GitLens的图标,选择Toggle File Blame 界面显示当前打开文件的所有修改历史记录 鼠标放到某条记录上,可以看到记录详情,选中O…