欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  数据库

两个 mysql SQL优化技艺

程序员文章站 2022-04-22 11:13:24
...

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