MySQL数据库小调优一例
沉沙 2018-05-17 来源 : 阅读 647 评论 0

摘要:本篇MySQL数据库教程讲解了一个优化案例,当sql单独拿出来执行速度非常快但大量执行该SQL就会有问题,采用消除文件排序的优化思路,希望本文对大家学习MySQL数据库有所帮助。

原始SQL:

select  distinct metadatalogid,opertime from xwcmmetadatalog where metadataid='4395597' order by opertime desc;

执行计划:

MariaDB [test]> explain select  distinct metadatalogid,opertime from xwcmmetadatalog where metadataid='4395597' order by opertime desc;
+------+-------------+-----------------+------+-------------------------------+-------------------------------+---------+-------+------+-----------------------------+| id   | select_type | table           | type | possible_keys                 | key                           | key_len | ref   | rows | Extra                       |
+------+-------------+-----------------+------+-------------------------------+-------------------------------+---------+-------+------+-----------------------------+
|    1 | SIMPLE      | xwcmmetadatalog | ref  | IX_xwcmmetadatalog_METADATAID | IX_xwcmmetadatalog_METADATAID | 5       | const |    1 | Using where; Using filesort |
+------+-------------+-----------------+------+-------------------------------+-------------------------------+---------+-------+------+-----------------------------+1 row in set (0.00 sec)

我们可以看到该执行计划其实问题也不是很大,唯一需要注意的就是用到了文件排序,当MySQL SERVER io比较吃紧的时候大量执行该SQL就会有问题了,所以我们优化思路就是消除这个文件排序即可。
查看索引

MariaDB [test]> show index from xwcmmetadatalog;
+-----------------+------------+----------------------------------+--------------+---------------+-----------+-------------+----------+--------+------+------------+---------+---------------+| Table           | Non_unique | Key_name                         | Seq_in_index | Column_name   | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment |
+-----------------+------------+----------------------------------+--------------+---------------+-----------+-------------+----------+--------+------+------------+---------+---------------+| xwcmmetadatalog |          0 | PRIMARY                          |            1 | METADATALOGID | A         |           0 |     NULL | NULL   |      | BTREE      |         |               || xwcmmetadatalog |          1 | IX_xwcmmetadatalog_SRCMETADATAID |            1 | SRCMETADATAID | A         |           0 |     NULL | NULL   | YES  | BTREE      |         |               || xwcmmetadatalog |          1 | IX_xwcmmetadatalog_METADATAID    |            1 | METADATAID    | A         |           0 |     NULL | NULL   | YES  | BTREE      |         |               |
+-----------------+------------+----------------------------------+--------------+---------------+-----------+-------------+----------+--------+------+------------+---------+---------------+3 rows in set (0.00 sec)

执行计划用到的索引只包含METADATAID列,而我们的sql筛选条件不仅包含metadataid='4395597' 还用到了opertime来排序,所以我们针对这两个字段建立索引即可。

MariaDB [test]> create index idx_medataid_opertime on xwcmmetadatalog(metadataid,opertime);Query OK, 0 rows affected (0.01 sec)Records: 0  Duplicates: 0  Warnings: 0

再次查看执行计划:

MariaDB [test]> explain select  distinct metadatalogid,opertime from xwcmmetadatalog where metadataid='4395597' order by opertime desc;
+------+-------------+-----------------+------+-----------------------------------------------------+-----------------------+---------+-------+------+--------------------------+| id   | select_type | table           | type | possible_keys                                       | key                   | key_len | ref   | rows | Extra                    |
+------+-------------+-----------------+------+-----------------------------------------------------+-----------------------+---------+-------+------+--------------------------+
|    1 | SIMPLE      | xwcmmetadatalog | ref  | IX_xwcmmetadatalog_METADATAID,idx_medataid_opertime | idx_medataid_opertime | 5       | const |    1 | Using where; Using index |
+------+-------------+-----------------+------+-----------------------------------------------------+-----------------------+---------+-------+------+--------------------------+1 row in set (0.00 sec)

完美


本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注数据库MySQL频道!

本文由 @沉沙 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程