优化MySQL查询避免在哪里?临时使用;使用文件排序。
技术问答
349 人阅读
|
0 人回复
|
2023-09-14
|
我使用MySQL为自己的网站建立了一个自定义论坛。列表页面本质上是一个包含以下各列的表: 主题 ,最近更新 和 #回复 。# c* y0 |8 F/ K, N
DB以下表:6 M% E1 F' {3 p2 q I
idnamebodydatetopic_idemail一个 主题 为“0”的topic_id,并 回复 有自己的母亲话题topic_id。; G; X" ^- B7 Z; ^# h8 `1 p
SELECT SQL_CALC_FOUND_ROWS t.id,t.name,MAX(COALESCE(r.date,t.date)) AS date,COUNT(r.id) AS repliesFROM wp_pod_tbl_forum tLEFT OUTER JOIN wp_pod_tbl_forum r ON (r.topic_id = t.id)WHERE t.topic_id = 0GROUP BY t.idORDER BY date DESC LIMIT 0,20;该表共有约2100个项目,查询通常需要6秒钟。2 h! X# V1 l0 J( t, E) Z) N8 C# L6 Y
topic_id添加列中INDEX,但这并没有多大帮助。在没有重大重组的情况下,有没有办法加快查询速度?! n1 q/ U' X4 Q! J- J+ g) Z! U& B
编辑 :工作不太好。我似乎无法使下面的例子正常工作。
G1 \* ]: ]& C3 Z% @# m
% g1 i; S8 k( ^$ L 解决方案:
2 O0 _. ]' c' v 2020假如你的手表是MyISAM或id不是PRIMARY KEY,你需要创建一个复合材料ondex (topic_id,id)。* u @( x6 {2 z
假如你的手表是,InnoDB并且id是PRIMARY KEY,只创建索引(topic_id)可以了(id将隐式添加到索引中)。0 h7 h5 S1 G& m
更新. W& b$ O8 y# n, [; [8 I2 w: _
如果你必须对索引进行索引,这个查询可能会更有效(topic_id,id)和(date,id):
M" @* \8 }$ }5 x; _6 E( m详情请参阅我的博客:5 e5 k$ o1 E, N# z7 o) |
选择最后的论坛帖子30 已完成查询ms样本数据为10000行:
5 d" [% s$ f% NSELECT id,name,last_reply, SELECT COUNT(*) FROM wp_pod_tbl_forum fc WHERE fc.topic_id = fl.topic_id AS repliesFROM ( SELECT topic_id,date AS last_reply FROM wp_pod_tbl_forum fo WHERE id = SELECT id FROM wp_pod_tbl_forum fp WHERE fp.topic_id = fo.topic_id ORDER BY fp.date DESC,id DESCLIMIT 20id DESCLIMIT 20有效查询这两个索引是必要的。
+ l( S7 k6 A$ p! H+ a" m, _1 h# x如果您的表是,InnoDB 并且 id是PRIMARY KEY,则您可以从indexes上面省略id 。 |
|
|
|
|
|