天天看點

關于MYSQL索引優化和in or替換為union all

mysql會對sql語句做優化, in 後面的條件不超過一定數量仍然會使用索引。

mysql 會根據索引長度和in後面條件數量判斷是否使用索引。

關于MYSQL索引優化和in or替換為union all

另外,如果是in後面是子查詢,則不會使用索引。

一個文章庫,裡面有兩個表:category和article。category裡面有10條分類資料。article裡面有 20萬條。article裡面有一個"article_category"字段是與category裡的"category_id"字段相對應的。 article表裡面已經把 article_category字義為了索引。資料庫大小為1.3G。

問題描述:

執行一個很普通的查詢: Select * FROM `article` Where article_category=11 orDER BY article_id DESC LIMIT 5 。執行時間大約要5秒左右

解決方案:

建一個索引:create index idx_u on article (article_category,article_id);

Select * FROM `article` Where article_category=11 orDER BY article_id DESC LIMIT 5 減少到0.0027秒

繼續問題:

Select * FROM `article` Where article_category IN (2,3) orDER BY article_id DESC LIMIT 5 執行時間要11.2850秒。

使用OR:

select * from article

where article_category=2

or article_category=3

order by article_id desc

limit 5

執行時間:11.0777

解決方案:避免使用in 或者 or (or會導緻掃表),使用union all

使用UNION ALL:

(select * from article where article_category=2 order by article_id desc limit 5)

UNION ALL (select * from article where article_category=3 order by article_id desc limit 5)

orDER BY article_id desc

limit 5

執行時間:0.0261

轉載于:http://blog.csdn.net/adparking/article/details/6678911

繼續閱讀