程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> 關於MYSQL索引優化和in or替換為union all的問題

關於MYSQL索引優化和in or替換為union all的問題

編輯:MySQL綜合教程


一個文章庫,裡面有兩個表: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秒  www.2cto.com     繼續問題: 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   www.2cto.com   解決方案:避免使用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
    作者 adparking

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved