mysql优化之sql语句优化、以及mysql一些高频面试题

文章目录

  • 一、索引
    • 1、什么是索引
    • 2、添加索引的原则
    • 3、索引的优缺点
    • 4、索引分类
    • 5、mysql存储过程(方法)
  • 二、MySQL的逻辑架构
    • 1、逻辑架构
    • 2、MyISAM 和 InnoDB的区别
  • 三、mysql的索引数据结构
    • 1、B Tree
    • 2、B+ Tree
  • 四、缓冲池 Buffer Pool
    • 1、预读机制
    • 2、预读失效
    • 3、淘汰策略
  • 五、Explain 用法
    • 1、id
    • 2、type
    • 3、key_len
    • 4、extra
    • 5、总结
  • 六、SQL的优化方案
    • 1、sql语句优化方案
    • 2、口诀
    • 3、其他优化方案


一、索引

1、什么是索引

索引是一种用于加速数据查询和排序操作的数据结构。它类似于书籍的目录,可以帮助数据库快速定位和获取所需的数据,从而提高查询的效率

2、添加索引的原则

经常查询的字段,添加索引,不经常查询的字段,就不要添加索引
字段中的数据,如果有大量重复的,该字段不能添加
一个表不要添加很多索引,最多2~3个索引

3、索引的优缺点

1、添加索引,查询速度非常的快
2、新增,修改和删除数据比较慢
3、添加索引,无形中占用了我们的空间

4、索引分类

1) 主键索引 所有的主键都是⼀种索引,天然的。
2) 唯⼀索引 将⼀个类设置为unique ,这种设置也是⼀种索引。
3) 普通索引 表中的普通类,可以设置为普通索引
4) 联合索引 由多个列组成的索引

-- 如果设计表的时候忘记添加索引,可以后来追加
alter table sc01 add primary key(sid); -- 追加主键
alter table sc01 add unique(sid); -- 追加唯一索引
alter table sc01 add index sname; -- 追加普通索引

5、mysql存储过程(方法)

存储过程其实就是一个类似于方法的SQL片段,用于提供一个功能。可以反复调用

drop procedure if exists 'init_data';  -- 如果名字存在就删除
delimiter ;;  -- 声明存储过程结束符号为;;-- 类似于java中方法的参数(in用来接收参数,out用来接收返回值)  declare 定义局部变量
create procedure 'init_data' (in data_count int)  
begin  -- begin end 类似于java中的{}declare i int default 0;  -- i的默认值设置为0while i < data_count do  -- 循坏data_count次insert into student values (i,'zhangsan',round((rand() * 100)));  -- 插入数据end while ;
end ;;
delimiter ;  --  将结束符号重新声明为;call init_data(5000);  -- 执行存储过程 传入参数

二、MySQL的逻辑架构

1、逻辑架构

连接层
连接层是一些客户端和连接服务
服务层
服务层主要完成大多数的核心服务功能,如SQL接口等
引擎层
存储引擎层,存储引擎真正的负责了MySQL中数据的存储和提取,服务器通过API与存储引擎进行通信。不同的存储引擎具有的功能不同。
存储层
数据存储层,主要是将数据存储在运行于裸设备的文件系统之上,并完成与引擎层的交互

2、MyISAM 和 InnoDB的区别

[图片]

这两个引擎,MyISAM 注重性能,读取数据的速度非常的快,InnoDB注重事务,注重安全,读取速度比较慢。
我们企业中,一般会做一个MySQL主从复制 可以将主的MySQL服务器,配置为InnoDB, 从服务器可以配置为MyISAM,因为它负责读,可以做到读写分离。

三、mysql的索引数据结构

1、B Tree

[图片]

B Tree 的缺点:

B Tree 上的每一个节点都存放的有数据,会导致存放的节点比较少,没有B+Tree多
B Tree 在进行范围查找的时候,查询次数比较多,效率低

2、B+ Tree

[图片]

B+ Tree 对比B Tree 的优点:

有序的,想查找某个范围速度非常的快
数据节点和指针分开了,一次获取到的数据比B Tree多很多,这样的设计,同样是三层架构,可以存储的数据比较多

四、缓冲池 Buffer Pool

缓冲池,简单来说就是一块内存区域。它存在的原因之一是为了避免每次都去访问磁盘,把最常访问的数据放在缓存里,提高数据的访问速度。

1、预读机制

在查询时,mysql的innodb会提前预读多条数据,存入缓冲池中,从而优化I/O,减少IO操作

2、预读失效

在进行预读时,缓冲池会加载大量的数据页,从而导致缓冲池中已存在的常用的数据页替换出去,造成缓冲池污染
此时会通过淘汰策略来将一些数据合理的淘汰清除掉

3、淘汰策略

LFU:最近最不常用算法,根据数据的历史访问频率来淘汰数据,Frequently 为频率的意思
LRU:最近最少使用算法,根据数据的历史访问记录来进行淘汰数据,Recently 为最近的意思
ARC:自适应替换缓存算法,结合了LRU和LFU的优点
FIFO:先进先出算法,淘汰最早进入缓存的数据项

五、Explain 用法

Explain :用于分析SQL语句的关键字

1、id

id如果相同,可以认为是一组,从上往下顺序执行;
在所有组中,id值越大,优先级越高,越先执行

2、type

这个指标是说明我们这个SQL是好还是坏的一个非常重要的指标;
system > const > eq_ref > ref > range > index > ALL SQL从好变坏

eq_ref:唯一性索引扫描,对于每个索引键,表中只有一条记录与之匹配。常见于主键或唯一索引扫描
Index:称之为覆盖索引 即联合索引的全字段匹配
ALL: 遍历全表以找到匹配的行,没有使用到索引

3、key_len

表示索引中使用的字节数,可通过该列计算查询中使用的索引的长度。在不损失精确性的情况下,长度越短越好(char类型就比varchar短两位,null比not null长1位)

4、extra

包含不适合在其他列中显示但十分重要的额外信息

1)Using filesort (出现这个说明非常不好) :进行order by的时候没有使用到索引建立的梯子,中间有断层
2)Using temporary (出现这个说明非常不好) :使了用临时表保存中间结果
3)using index 说明还可以,还不错 :表示相应的select操作中使用了覆盖索引,避免访问了表的数据行
4)Using where 表明使用了where过滤
5)using join buffer :使用了连接缓存
6 impossible where :where子句的值总是false,不能用来获取任何元素。 比如:select * from user where name=“张三” and name=”李四

5、总结

通过 explain 进行sql分析的时候,其实就是查看这个大的SQL拆分以后,每一个小的SQL语句是如何执行的。
并且查看每一个小的SQL语句它的type类型 和 Extra 这两个字段的值
查看type类型是否为ALL
查看Extra 这个字段是否出现 filesort temporary

六、SQL的优化方案

1、sql语句优化方案

– 1、全字段匹配
– 2、最佳左前缀法则
– 3、索引列上不计算
– 4、不能使用索引中范围条件右边的列
– 5、尽量使用覆盖索引(只访问索引的查询(索引列和查询列一致)),减少select *
– 6、使用不等于(!= 或者<>)的时候无法使用索引
– 7、注意字段的null值和 not null 对sql的影响
– 8、like以通配符开头(‘%abc…’)mysql索引失效
– 9、字符串不加单引号索引失效 (底层使用数据类型转换)
– 10、少用or,用它来连接时会索引失效

2、口诀

– 全值匹配才最棒,最佳左前缀法则;
– 刘备大哥不能死,关羽兄弟不能断;
– 索引列上少计算,范围之后全完蛋;
– like百分写最右,覆盖索引有妙用;
– 不等空值还有OR,索引影响要注意;

3、其他优化方案

– ● 索引优化: 合理设计索引,优化查询性能,避免全表扫描。
– ● 查询优化: 优化SQL查询语句,避免慢查询,提高查询效率。
– ● 缓存优化: 合理利用MySQL内置的缓存机制,如查询缓存、结果缓存等,减少对数据库的访问次数。
– ● 硬件优化: 选择合适的硬件配置,包括CPU、内存、磁盘等,提高数据库的吞吐量和响应速度。

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

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

相关文章

Qt中多语言的操作(以QtCreator为例)

1、首先&#xff0c;我们在代码中与文本相关的且需要支持多语言的地方&#xff0c;用tr来包含多语言key&#xff08;多语言key是我们自己定义的&#xff09;&#xff0c;如下 //举例 QPushButton* btnnew QPushButton(this); btn->move(20,20); btn->resize(100,50); //…

Selenium with Python学习笔记整理(网课+网站持续更新)

本篇是根据学习网站和网课结合自己做的学习笔记&#xff0c;后续会一边学习一边补齐和整理笔记 学习网站&#xff1a; selenium 实战二_PO代码重构 Selenium自动化测试python篇 看云 https://selenium-python.readthedocs.io/getting-started.html#simple-usage WEB UI自…

erlang学习:Linux命令学习4

顺序控制语句学习 if&#xff0c;else对文件操作 判断一个文件夹是否存在&#xff0c;如果存在则进行删除&#xff0c;如果不存在则创建该文件夹&#xff0c;并复制一份该脚本后&#xff0c;删除该脚本 if [ -d "/erlangtest/testdir"]; then echo "删除文件夹…

【路径规划】绘制算术和几何布朗运动- 绘制布朗桥、2D 和 3D 布朗运动- 绘制一些随机路径

摘要 本文演示了如何生成和绘制布朗运动、几何布朗运动和布朗桥的随机路径。这些随机路径广泛应用于金融、物理和工程领域&#xff0c;用于模拟随机过程。实验结果包括了多条随机路径的示例&#xff0c;展示了不同类型的布朗运动的特征。 理论 1. 布朗运动 (Brownian Motion…

构建高效房屋租赁系统:Spring Boot应用

1 绪论 1.1 研究背景 中国的科技的不断进步&#xff0c;计算机发展也慢慢的越来越成熟&#xff0c;人们对计算机也是越来越更加的依赖&#xff0c;科研、教育慢慢用于计算机进行管理。从第一台计算机的产生&#xff0c;到现在计算机已经发展到我们无法想象。给我们的生活改变很…

如何在NXP源码基础上适配ELF 1开发板的UART功能

UART即通用异步收发器&#xff0c;是一种支持全双工串行通信协议的接口。在i.MX6ULL处理器平台上&#xff0c;该处理器原生支持多达8路的UART接口&#xff0c;提供了丰富的串行通信能力。 针对ELF 1开发板&#xff0c;实际引出了4路UART接口供开发者使用&#xff0c;具体包括U…

Node-RED-L2-Node-RED在Linux系统启动时自动运行

Node-RED在Linux系统启动时自动运行 目的步骤1创建服务文件&#xff1a;2重新加载服务&#xff1a;3启用服务&#xff1a;4启动Node-RED服务&#xff1a;5检查服务状态&#xff1a;6其他说明7如果没启动正确的Node-RED执行路径&#xff1a;确保使用绝对路径&#xff1a; 检查用…

Flutter 约束布局

配置插件依赖 设置组件大小 通过属性 childConstraints 实现 分别设置 约束布局一 和 约束布局二 大大小为:160 和 200 点击查看代码文件 class SummaryPageState extends State<SummaryPage1> {ConstraintId constraintId_1 = ConstraintId(ConstraintId_1);Constrain…

易航网址导航系统V2.45完美去授权版

简介 易航网址导航系统V2.45完美去授权版 界面

Spring(看这一篇就够了)

Spring 概述 Spring 是最受欢迎的企业级 Java 应用程序开发框架&#xff0c;数以百万的来自世界各地的开发人员使用 Spring 框架来创建性能好、易于测试、可重用的代码。 Spring 框架是一个开源的 Java 平台&#xff0c;它最初是由 Rod Johnson 编写的&#xff0c;并且…

SFUD库移植

1.源码 GitHub - armink/SFUD: An using JEDECs SFDP standard serial (SPI) flash universal driver library | 一款使用 JEDEC SFDP 标准的串行 (SPI) Flash 通用驱动库 2.介绍 这个通用驱动库,实际就是帮你封装好了读写spiflash的函数, 我们只需要对接以下底层,就可以轻松…

【个人笔记】线程和线程池的状态以及转换方式

线程和线程池的状态是不一样的&#xff01;&#xff01; 线程有 6 种状态&#xff0c;查看Thread的State枚举类&#xff1a; NEW&#xff1a;创建后没启动的线程就处于这种状态RUNNABLE&#xff1a;正在java虚拟机中执行的线程就处于这种状态BLOCKED&#xff1a;受阻塞并等待…

Observability:构建下一代托管接入服务

作者&#xff1a;来自 Elastic Vishal Raj, Marc Lopez Rubio 随着无服务器&#xff08;serverless&#xff09;的引入&#xff0c;向 Elastic Cloud 发送可观察性数据变得越来越容易。你可以在 Elastic Cloud Serverless 中创建一个可观察性无服务器项目&#xff0c;并将可观察…

【Java】虚拟机(JVM)内存模型全解析

目录 一、运行时数据区域划分 版本的差异&#xff1a; 二、程序计数器 程序计数器主要作用 三、Java虚拟机 1. 虚拟机运行原理 2. 活动栈被弹出的方式 3. 虚拟机栈可能产生的错误 4. 虚拟机栈的大小 四、本地方法栈 五、堆 1. 堆区的组成&#xff1a;新生代老生代 …

Ubuntu磁盘不足扩容

1.问题 Ubuntu磁盘不足扩容 2.解决方法 安装一下 sudo apt-get install gpartedsudo gparted

Mysql梳理6——order by排序

目录 6 order by排序 6.1 排序数据 6.2 单列排序 6.3 多行排列 6 order by排序 6.1 排序数据 使用ORDER BY字句排序 ASC&#xff08;ascend&#xff09;:升序DESC(descend):降序 ORDER BY子句在SELECT语句的结尾 6.2 单列排序 如果没有使用排序操作&#xff0c;默认…

C语言课程设计题目一:职工信息管理系统设计

文章目录 题目一&#xff1a;职工信息管理系统设计代码块employeeManagement.hemployeeManage.ctest.c 调试验证录入信息&#xff0c;并浏览验证职工号唯一保存职工信息&#xff0c;加载职工信息按职工号进行查询根据id删除职工修改职工信息 题目一&#xff1a;职工信息管理系统…

下水道内缺陷识别检测数据集 yolo数据集 共2300张

下水道内缺陷识别检测数据集 yolo数据集 共2300张 下水道内部缺陷识别数据集&#xff08;Sewer Interior Defect Recognition Dataset, SIDRD&#xff09; 摘要 SIDRD 是一个专门针对下水道内部缺陷识别的数据集&#xff0c;旨在为城市基础设施维护和管理提供一个标准化的训练…

VmWare安装虚拟机保姆级教程(centos7,虚拟机网络设置,虚拟机桌面显示)

VMWare下载&#xff1a; 下载 VMware Workstation Pro - VMware Customer Connect 安装包&#xff1a;&#xff08;16的版本&#xff09;免费&#xff01;&#xff08;一个赞就行&#xff09; 一直点下一步即可&#xff0c;注意修改一下安装位置就好 二、安装虚拟机 安装虚…

论文复现:考虑电网交互的风电、光伏与电池互补调度运行(MATLAB-Yalmip-Cplex全代码)

论文复现:考虑电网交互的风电、光伏与电池储能互补调度运行(MATLAB-Yalmip-Cplex全代码) 针对风电、光伏与电化学储能电站互补运行的问题,已有大量通过启发式算法寻优的案例,但工程上更注重实用性和普适性。Yalmip工具箱则是一种基于MATLAB平台的优化软件工具箱,被广泛应用…