教做湘菜的视频网站,哈尔滨市政建设工程,怎样退订3d卫星街景会员费用,工信部网站备案号MYSQL描述#xff1a;一个文章库#xff0c;里面有两个表#xff1a;category和article。category里面有10条分类数据。article里面有 20万条。article里面有一个article_category字段是与category里的category_id字段相对应的。 article表里面已经…MYSQL描述一个文章库里面有两个表category和article。category里面有10条分类数据。article里面有 20万条。article里面有一个article_category字段是与category里的category_id字段相对应的。 article表里面已经把 article_category字义为了索引。数据库大小为1.3G。问题描述执行一个很普通的查询 SELECT * FROM article WHERE article_category11 ORDER BY article_id DESC LIMIT 5 。执行时间大约要5秒左右解决方案建一个索引create index idx_u on article (article_category,article_id);SELECT * FROM article WHERE article_category11 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 articlewhere article_category2or article_category3order by article_id desclimit 5执行时间11.0777解决方案避免使用in 或者 or (or会导致扫表)使用union all使用UNION ALL(select * from article where article_category2 order by article_id desc limit 5)UNION ALL (select * from article where article_category3 order by article_id desc limit 5)ORDER BY article_id desclimit 5执行时间0.0261