两个 mysql SQL优化技艺

两个 mysql SQL优化技巧

1, limit offset 优化

? ? ? ?mysql >SELECT * FROM `bigtable` order by value limit 50,5;

? ? ? ?优化后:

? ? ? ?mysql >EXPLAIN SELECT * FROM `bigtable`

? ? ? ? ? ? ? ? INNER JOIN(

? ? ? ? ? ??select id from `bigtable` order by value limit 50,5

? ? ? ? ? ? ? ? ?) as lim USING(id);

? ? ? ?说明:通过联结先取得符合条件的主键ID,然后再在原表上查找剩余的行,这样减少了读取无用行中的数据。

? ? ? ?如果事先将limit 分页计算出索引列的准确位置,那么可以使用索引范围扫描,写成这样:

? ? ? mysql >SELECT * FROM `bigtable` where position between 5 and 10 order by position;

? ? ? position 是bigtable 表的一列。

2, 始终使用union all 代替union ,除非需要服务器消除重复的行。

两个 mysql SQL优化技艺

相关文章:

你感兴趣的文章:

标签云: