首页 > 数据库 >mysql优化之sql语句优化、以及mysql一些高频面试题

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

时间:2024-09-25 18:49:29浏览次数:10  
标签:面试题 -- mysql Tree 存储 查询 索引 SQL 优化

文章目录


一、索引

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的默认值设置为0
    while 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、内存、磁盘等,提高数据库的吞吐量和响应速度。

标签:面试题,--,mysql,Tree,存储,查询,索引,SQL,优化
From: https://blog.csdn.net/lzhlizihang/article/details/142414549

相关文章

  • 后端开发面试题8(附答案)
    前言    在下首语言是golang,所以会用他作为示例。原文参见@arialdomartini的:Back-EndDeveloperInterviewQuestions软件架构相关问题 1.什么情况下缓存是没用的,甚至是危险的?        缓存设计的目的在于提高数据访问速度和减轻数据库的压力,但它并非......
  • 深入探索 RUM 与全链路追踪:优化数字体验的利器
    作者:梅光辉(重彦)背景介绍随着可观测技术的持续演进,多数企业已广泛采用APM、Tracing及Logging解决方案,以此强化业务监控能力,尤其在互联网行业,产品的体验直接关系着用户的口碑,决定了市场命运,使得RUM(真实用户监控)日益受到重视。然而,在面对由后端服务故障引起的体验问题时(例如,后......
  • mysql数据库 - anolisos安装
    文章目录一、anolisos系统介绍1.1、anolisos系统的起源1.2、anolisos系统的版本支持1.3、anolisos系统的特点1.4、anolisos系统的适用场景二、环境部署2.1、修改主机名2.2、修改静态ip地址2.3、关闭selinux2.4、关闭或放通防火墙端口三、安装mysql数据库3.1、更新yum源......
  • Linux常用命令(Mysql)
    --删除表内数据(Mysql)usedc;#切换到待删除表所在的数据库truncatetable[表名]#删除表--数据库导入SQL文件数据(Mysql)sourcea.sql;--SQL增删改查insertintostudent(id,name,sex,birth)values('01','赵雷','男','1990');deletefromstudentwhereid=......
  • Windows Server 安装MySQL教程(图文)
    本篇教程,在服务器WindowsServer2016(中文版)上安装MySQL8.0,并记录详细的安装步骤。1、下载安装包在mysql官网上下载安装包下载地址:https://dev.mysql.com/downloads/installer/2、安装步骤下载之后,双击运行mysql-installer-community-8.0.39.0.msi如果双击无反应,那么需要安装一......
  • MySQL SQL基础常见面试题整理
    NOSQL和SQL的区别是什么?SQL数据库是指关系型数据库,主要有:SQLServer,Oracle,MySQL(开源),PostgreSQL(开源)。关系型数据库用于存储结构化数据,这些数据在逻辑上以行和列的二维表形式存在,每一列代表一个数据属性,每一行则代表一个数据实体。NoSQL是指非关系型数据库,主要有MongoDB和......
  • Linux中MySQL配置主主复制操作
    一、GTIDGTID(GlobalTransactionIdentifier)是MySQL的一种用于标识分布式环境中事务的全局唯一标识符。它在MySQL的主从复制场景中尤为重要,尤其是在使用MariaDB或MySQL5.6及更高版本的环境中。GTID由两部分组成:服务器ID(标识执行该事务的服务器)和事务序号(表示在该服务器上执......
  • 最强Java100道核心面试题
    1.讲讲你理解的nio和bio的区别是啥,谈谈reactor模型。IO(BIO)是面向流的,NIO是面向缓冲区的BIO:BlockIO同步阻塞式IO,就是我们平常使用的传统IO,它的特点是模式简单使用方便,并发处理能力低。NIO:NewIO同步非阻塞IO,是传统IO的升级,客户端和服务器端通过Channel(通道)通......
  • 解读MySQL8.0数据字典重构源码
    摘要:本文对社区MySQL5.7到8.0演进过程中数据字典DD的重构(缓存,持久化),AtomicDDL的关键实现进行了分析。本文分享自华为云社区《【华为云MySQL技术专栏】MySQL8数据字典重构源码解读》,作者:GaussDB数据库1.背景介绍在MySQL5.7版本的使用实践过程中,我们很容易遇到DDL崩溃后导致数......
  • 广州浮点Tekla软件许可优化实施成功案例
    浮动版Tekla软件许可证优化、降本增效实施行业:建筑工程实施软件:TeklaStructures软件一、背景概述1.项目背景TeklaStructures是广泛应用于建筑工程、钢结构设计和土木工程领域的建筑信息建模(BIM)软件,能够处理复杂的结构设计和精确的施工规划。一家大型建筑工程公司在其多个......