MySQL查询rank优化_mysql查询优化--临时表和文件排序(Using temporary; Using filesort问题解决)...

先看一段sql:

SELECT

*

FROM

rank_user ASrankUser

LEFTJOINrank_user_levelASuserLevelONrankUser.id = userLevel.user_id

LEFTJOINrank_productASproductONuserLevel.new_level = product.level_id

LEFTJOINrank_product_feeASfeeONuserLevel.fee_id = fee.fee_id

LEFTJOINrank_user_login_statASuserLoginInfoONrankUser.id = userLoginInfo.user_id

ORDERBY

rankUser.create_time DESC

LIMIT 10 OFFSET 0SELECT

*

FROM

rank_user AS rankUser

LEFT JOIN rank_user_level AS userLevel ON rankUser.id = userLevel.user_id

LEFT JOIN rank_product AS product ON userLevel.new_level = product.level_id

LEFT JOIN rank_product_fee AS fee ON userLevel.fee_id = fee.fee_id

LEFT JOIN rank_user_login_stat AS userLoginInfo ON rankUser.id = userLoginInfo.user_id

ORDER BY

rankUser.create_time DESC

LIMIT 10 OFFSET 0

介绍一下这段sql的表的构成:一张主表:rank_user;两张跟rank_user直接关联(多张表通过同一字段最好是主键进行关联)的表:rank_user_level ,rank_user_login_stat ;两张跟rank_user非直接关联的表:rank_product ,rank_product_fee 。这段sql看似简单,但是执行时间却很长,我们来看一下执行计划:

3e1d6e46c4bfcdc320405fd10ccb6a48.png

执行时间1.45s,可以看到,这段不仅仅扫描全表,而且使用了临时表,进行了文件排序。

为了找到原因,我们把排序去掉看一下:

SELECT

*

FROM<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值