一個(gè)文章庫(kù),里面有兩個(gè)表:category和article。category里面有10條分類(lèi)數(shù)據(jù)。article里面有 20萬(wàn)條。article里面有一個(gè)article_category字段是與category里的category_id字段相對(duì)應(yīng)的。 article表里面已經(jīng)把 article_category字義為了索引。數(shù)據(jù)庫(kù)大小為1.3G
一個(gè)文章庫(kù),里面有兩個(gè)表:category和article。category里面有10條分類(lèi)數(shù)據(jù)。article里面有 20萬(wàn)條。article里面有一個(gè)”article_category”字段是與category里的”category_id”字段相對(duì)應(yīng)的。 article表里面已經(jīng)把 article_category字義為了索引。數(shù)據(jù)庫(kù)大小為1.3G。
問(wèn)題描述:
執(zhí)行一個(gè)很普通的查詢(xún): Select * FROM `article` Where article_category=11 ORDER BY article_id DESC LIMIT 5 。執(zhí)行時(shí)間大約要5秒左右
解決方案:
建一個(gè)索引: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秒
繼續(xù)問(wèn)題:
Select * FROM `article` Where article_category IN (2,3) ORDER BY article_id DESC LIMIT 5 執(zhí)行時(shí)間要11.2850秒。
使用OR:
select * from article
where article_category=2
or article_category=3
order by article_id desc
limit 5
執(zhí)行時(shí)間:11.0777
解決方案:避免使用in 或者 or (or會(huì)導(dǎo)致掃表),使用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
執(zhí)行時(shí)間:0.0261