快上网建站品牌

13518219792
  • 首页
  • 关于我们
    • 如何选择
    • 选择理由
  • 案例作品
    • 网站建设
    • 优化推广
    • 微信开发
    • 电商托管
  • 服务项目
    • 网站建设
    • 移动端/APP
    • 微信/小程序
    • 技术支持
    • 其它服务
  • 建站知识
    • 成都网站建设
    • 成都做网站
    • 成都网站设计
  • 网站售后
    • 成都网站运营
    • 成都网站维护
    • 成都网站推广
  • 客服中心
  • 全国分站

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

  • 《两个工具分析SQL死锁》
  • 《SQL空值带来的大坑》

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

创新互联不只是一家网站建设的网络公司;我们对营销、技术、服务都有自己独特见解,公司采取“创意+综合+营销”一体化的方式为您提供更专业的服务!我们经历的每一步也许不一定是最完美的,但每一步都有值得深思的意义。我们珍视每一份信任,关注我们的成都网站制作、网站建设、外贸网站建设质量和服务品质,在得到用户满意的同时,也能得到同行业的专业认可,能够为行业创新发展助力。未来将继续专注于技术创新,服务升级,满足企业一站式营销型网站建设需求,让再小的品牌网站设计也能产生价值!

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

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

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

数据准备:

 
 
 
 
  1. create table user ( 
  2. id int primary key, 
  3. name varchar(20), 
  4. sex varchar(5), 
  5. index(name) 
  6. )engine=innodb; 
  7.   
  8. insert into user values(1, 'shenjian','no'); 
  9. insert into user values(2, 'zhangsan','no'); 
  10. insert into user values(3, 'lisi', 'yes'); 
  11. insert into user values(4, 'lisi', 'no'); 

数据说明:

  • 用户表:id主键索引,name普通索引(非唯一),sex无索引;
  • 四行记录:其中name普通索引存在重复记录lisi;

实验目的:

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

一、【Using where】

实验语句:

 
 
 
 
  1. explain select * from user where sex='no'; 

结果说明:

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

需要注意的是:

  • 返回所有记录的SQL,不使用where条件过滤数据,大概率不符合预期,对于这类SQL往往需要进行优化;
  • 使用了where条件的SQL,并不代表不需要优化,往往需要配合explain结果中的type(连接类型)来综合判断;

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

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

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

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

二、【Using index】

实验语句:

 
 
 
 
  1. 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】

实验语句:

 
 
 
 
  1. explain select id,name,sex from user  
  2. where name='shenjian'; 

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

结果说明:

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

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

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

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

四、【Using filesort】

实验语句:

 
 
 
 
  1. explain select * from user order by sex; 

结果说明:

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

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

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

五、【Using temporary】

实验语句:

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

结果说明:

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

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

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

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

实验语句:

 
 
 
 
  1. 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,关联字段均未建立索引,就会出现这种情况。常见的优化方案是,在关联字段上添加索引,避免每次嵌套循环计算。

结尾:

explain是SQL优化中最常用的工具,搞定type和Extra,explain也就基本搞定了。

  • 《MySQL explain,type分析》进行了常见type分析
  • 本文进行了常见Extra分析
  • 《两个工具分析SQL死锁》和《SQL空值带来的大坑》是两篇典型案例分析
  • 《MyISAM与InnoDB的索引差异》是InnoDB和MyISAM索引差异分析
  • 《数据库索引,到底是什么做的?》是索引底层实现分析

以上几篇文章,强烈建议大家读透。

【本文为专栏作者“58沈剑”原创稿件,转载请联系原作者】

戳这里,看该作者更多好文


名称栏目:如何利用工具,迅猛定位低效SQL? | 1分钟系列
文章转载:http://csdahua.cn/article/ccdghhg.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流

其他资讯

  • 测试Redis的随机性能测试这是一次重要的考验(redis 随机性能)
  • postgresql数据库权限怎么设置
  • 描述Hibernate映射文件
  • 购买的虚拟主机可以搭建论坛吗(购买的虚拟主机可以搭建论坛吗安全吗)
  • Redis参数检查一览表(redis检查参数汇总)

行业动态

企业网站建设的重要性!

现在虽然是移动互联网时代,但企业网站依然重要,包含PC站点,移动站。可以说企业网站关系企业的未来发展和前途,尤其对中小企业更是如此,一些中小企业老板,对自己的名片很在乎,因为这是个门面。...

服务项目

  • 网站建设

    查看详情
  • 移动端/APP

    查看详情
  • 微信/小程序

    查看详情
  • 技术支持

    查看详情
  • 其它服务

    查看详情
  • 更多服务项目

    用我们的专业和诚信赢得您的信赖,从PC到移动互联网均有您想要的服务!

    获取更多

联系吧 在百度地图上找到我们

电话:13518219792

如遇占线或暂未接听请拨:136xxx98888

业务咨询 技术咨询 售后服务
网站制作
温江网站制作
盐亭网站制作公司
成都网站制作公司
成都网站制作
网站建设
营销型网站建设
网站建设方案
营销型网站建设
成都营销型网站建设
网站设计
成都网站设计
成都网站设计
网站设计公司
梓潼网站设计
联系我们
电话:13518219792
邮箱:631063699@qq.com
地址:成都青羊区锦天国际1002号
网址:www.csdahua.cn

微信二维码

  • 友情链接
  • vi形象设计
  • 德阳发电机
  • 成都网站推广
  • 四川绵阳机房
  • 成都棕树机房
  • 青白江柴油发电机回收
  • 产品质量认证
  • jnanhua.com
  • 渠县网站制作
  • 成都网站推广

Copyright © 2002-2023 www.csdahua.cn 快上网建站品牌 QQ:244261566 版权所有 备案号:蜀ICP备19037934号

  • 在线咨询
  • 13518219792
  • 微信二维码

  • 移动版官网