首頁 >資料庫 >mysql教程 >两个 mysql SQL优化技艺

两个 mysql SQL优化技艺

WBOY
WBOY原創
2016-06-07 16:24:03945瀏覽

两个 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` or

两个 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 ,除非需要服务器消除重复的行。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn