using filesort 一般出现在 使用了 order by 语句当中。
using filesort不一定引起mysql的性能问题。但是如果查询次数非常多,那么每次在mysql中进行排序,还是会有影响的。
这里的优化方式是在order by 的字段建立索引,例如 语句:
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 建立索引:
此时查看执行计划:
+----+-------------+----------+-------+---------------+-------------+---------+------+------+-------+
| 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查询的速度。