欢迎光临妙手医生大药房! 注册
网站导航 互联网药品交易服务资格证书编号:粤C20150017
手机版
  • 扫一扫

    扫一扫
    妙手购药更方便

  • 扫一扫

    扫一扫
    下载妙手医生

首页 > 妙手资讯> 儿科用药> 如何利用工具,迅猛定位低效SQL? | 1分钟系列

如何利用工具,迅猛定位低效SQL? | 1分钟系列

妙手医生

发布时间:2023-05-04阅读量:1.3w+次阅读
温馨提示:以下内容是针对圆心大药房网上药店展示的商品进行分享,方便患者了解日常用药相关事项。请患者在用药时(处方药须凭处方)在药师指导下购买和使用。

《两个工具分析SQL死锁》

《SQL空值带来的大坑》

两个案例分析,展现了MySQL性能分析工具explain的强大。

《同一个SQL语句,为啥性能差异咋就这么大呢?》

详细叙述了explain结果中最重要的type字段(连接类型)的含义。

 

其实,explain结果中还有一个Extra字段,对分析与优化SQL有很大的帮助,今天花1分钟简单和大家聊一聊。

 

数据准备

create table user (

id int primary key,

name varchar(20),

sex varchar(5),

index(name)

)engine=innodb;

 

insert into user values(1, "shenjian","no");

insert into user values(2, "zhangsan","no");

insert into user values(3, "lisi", "yes");

insert into user values(4, "lisi", "no");

 

数据说明

用户表:id主键索引,name普通索引(非唯一),sex无索引

四行记录:其中name普通索引存在重复记录lisi;

 

实验目的

通过构造各类SQL语句,对explain的Extra字段进行说明,启发式定位待优化低性能SQL语句。

 

一、【Using where】

实验语句

explain select * from user where sex="no";

 

结果说明

Extra为Using where说明,SQL使用了where条件过滤数据

 

需要注意的是:

(1)返回所有记录的SQL,不使用where条件过滤数据,大概率不符合预期,对于这类SQL往往需要进行优化;

(2)使用了where条件的SQL,并不代表不需要优化,往往需要配合explain结果中的type(连接类型)来综合判断;

画外音:join type在同一个SQL语句,为啥性能差异咋就这么大呢?一文中有详细叙述,本文不再展开。

 

本例虽然Extra字段说明使用了where条件过滤,但type属性是ALL,表示需要扫描全部数据,仍有优化空间。

 

常见的优化方法为,在where过滤属性上添加索引。

画外音:本例中,sex字段区分度不高,添加索引对性能提升有限。

 

二、【Using index】

实验语句

explain select id,name from user where name="shenjian";

 

结果说明

Extra为Using index说明,SQL所需要返回的所有列数据均在一棵索引树上,而无需访问实际的行记录

画外音:The column information is retrieved from the table using only information in the index tree without having to do an additional seek to read the actual row.

 

这类SQL语句往往性能较好。

 

问题来了,什么样的列数据,会包含在索引树上呢?

 

三、【Using index condition】

实验语句:

explain select id,name,sex from user 

where name="shenjian";

画外音:该SQL语句与上一个SQL语句不同的地方在于,被查询的列,多了一个sex字段。

 

结果说明:

Extra为Using index condition说明,确实命中了索引,但不是所有的列数据都在索引树上,还需要访问实际的行记录

画外音:聚集索引,普通索引的底层实现差异,详见《1分钟了解MyISAM与InnoDB的索引差异》。

 

这类SQL语句性能也较高,但不如Using index

 

问题来了,如何优化为Using index呢?

 

四、【Using filesort】

实验语句:

explain select * from user order by sex;

 

结果说明:

Extra为Using filesort说明,得到所需结果集,需要对所有记录进行文件排序

 

这类SQL语句性能极差,需要进行优化。

 

典型的,在一个没有建立索引的列上进行了order by,就会触发filesort,常见的优化方案是,在order by的列上添加索引,避免每次查询都全量排序。

 

五、【Using temporary】

实验语句:

explain select * from user group by name order by sex;

 

结果说明:

Extra为Using temporary说明,需要建立临时表(temporary table)来暂存中间结果

 

这类SQL语句性能较低,往往也需要进行优化。

 

典型的,group byorder by同时存在,且作用于不同的字段时,就会建立临时表,以便计算出最终的结果集。

 

六、【Using join buffer (Block Nested Loop)】

实验语句:

explain select * from user where id in(select id from user where sex="no");

 

结果说明:

Extra为Using join buffer (Block Nested Loop)说明,需要进行嵌套循环计算

画外音:内层和外层的type均为ALL,rows均为4,需要循环进行4*4次计算。

 

这类SQL语句性能往往也较低,需要进行优化。

 

典型的,两个关联表join,关联字段均未建立索引,就会出现这种情况。常见的优化方案是,在关联字段上添加索引,避免每次嵌套循环计算。

 


以上内容仅供参考

相关资讯

更多>
  • 如何利用工具,迅猛定位低效SQL? | 1分钟系列

    《两个工具分析SQL死锁》《SQL空值带来的大坑》两个案例分析,展现了MySQL性能分析工具explain的强大。《同一个SQL语句,为啥性能差异咋就这么大呢?》详细叙述了explain结果中最重要的type字段(连接类
    妙手医生
    1.3w+ 2023-05-04
  • 3分钟了解脑卒中

    3分钟了解脑卒中

    脑卒中在我国的死亡率居高不下,且多年来一直持续上升,目前我国每年新发脑血管疾病患者约为270万,每年死于脑血管病的患者约130万,每12秒就有一人发生脑卒中,每21秒就有人死于脑卒中。什么是脑卒中?脑卒中又称“中风”“脑
    按说
    326 2019-08-27
  • 散结镇痛胶囊的作用,1分钟记住

    散结镇痛胶囊的作用,1分钟记住

    视频内容:散结镇痛胶囊具有一定的镇痛、抗炎和解痉作用,它能抑制异位子宫内膜生长,对痛经、月经不调、不孕等子宫内膜异位典型症状具有明显的改善作用。散结镇痛胶囊主要成分是三七、薏苡仁、浙贝母和龙血竭,有软坚散结、化瘀止痛的功
    妙手医生
    305 2019-08-22
  • 1分钟速览:三问CPP临床诊疗

    1分钟速览:三问CPP临床诊疗

    性早熟是一种青春期提前出现的性发育异常疾病,女童一般在8岁前呈现第二性征。按发病机理和临床表现分为中枢性性早熟(CPP)和外周性性早熟,发病率为1/5000-1/10000[1]。现总结临床工作中CPP诊治的常见问题,为
    妙手医生
    3328 2022-08-31
  • 每天5分钟让你远离腰肌劳损

    每天5分钟让你远离腰肌劳损

    有没有发现腰这个器官很娇弱的,站的太久、坐得太久、拿东西太重都会腰痛。现在年轻人更是因为工作原因一坐一整天,腰酸背痛早已经不是老年人的专利,腰肌筋膜炎、腰肌劳损、腰椎间盘突出的年轻人比比皆是。那么平时我们如何保护腰呢?腰
    按说
    347 2019-08-20
妙手买药

妙手皮肤科医患交流群

妙手医生

妙手医生App

微信公众号

微信公众号