using filesort 通常出如今 使用了 order by 语句当中。mysql
using filesort不必定引发mysql的性能问题。可是若是查询次数很是多,那么每次在mysql中进行排序,仍是会有影响的。算法
这里的优化方式是在order by 的字段创建索引,例如 语句:sql
SELECT * FROM yw_syjgb ORDER BY result_date desc LIMIT 0,1000;性能
查看执行计划:测试
+----+-------------+----------+------+---------------+------+---------+------+---------+----------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+----------+------+---------------+------+---------+------+---------+----------------+
| 1 | SIMPLE | yw_syjgb | ALL | NULL | NULL | NULL | NULL | 1312418 | Using filesort |
+----+-------------+----------+------+---------------+------+---------+------+---------+----------------+优化
则须要在result_date 创建索引:spa
此时查看执行计划:排序
+----+-------------+----------+-------+---------------+-------------+---------+------+------+-------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+----------+-------+---------------+-------------+---------+------+------+-------+
| 1 | SIMPLE | yw_syjgb | index | NULL | result_date | 6 | NULL | 1000 | NULL |
+----+-------------+----------+-------+---------------+-------------+---------+------+------+-------+索引
能够看到执行计划中使用索引后没有 Using filesort内存
须要注意的是:因为 Using filesort是使用算法在 内存中进行排序,MySQL对于排序的记录的大小也是有作限制:max_length_for_sort_data,默认为1024
show variables like '%max_length_for_sort_data%';
+--------------------------+-------+
| Variable_name | Value |
+--------------------------+-------+
| max_length_for_sort_data | 1024 |
+--------------------------+-------+
通过笔者测试,若是排序查询的数据两大于这个默认值的话,仍是会使用Using filesort。
总结一句,当排序查询的数据量在默认值的范围内是,在排序的字段上加上索引能够提高MySQL查询的速度。