当前位置:   article > 正文

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

mysql rank优化

先看一段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<

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/天景科技苑/article/detail/938648
推荐阅读
相关标签
  

闽ICP备14008679号