0

希望优化此查询

SELECT gwt.z, gwt.csp, gwt.status, gwt.cd, gwt.disp, gwt.5d, gwt.6d, gwt.si, gwt.siad, gwt.prbd, 
  CONCAT(gwt.1, gwt.2, gwt.3, gwt.4, gwt.5, gwt.6, gwt.7, gwt.8, gwt.9), 
  group_concat(gws.res order by line_no), gwt.scm, gm.me, gwt.p, gwt.scd 
from gwt 
left outer join gws on gwt.csp = gws.csp 
left join gm on gwt.scm = gm.mid 
where gwt.zone = 1 
  and (status like '1%' or status like '2%' or status like '3%' or 
       status like '4%' or status like '5%' or status like '6%') 
group by gwt.csp

使用 EXPLAIN,gwt 有 4110 行,gws 有 920k 行,gm 有 2800 行。

当我只查询 1% 之类的状态时,查询加载正常,但由于我添加了要显示的其他状态,因此出现超时错误。

描述

4

2 回答 2

2

我建议以下。

确保每个表都有一个关于其主键的索引:

  • gwt.csp
  • gm.mid

对于 gwt,在 (zone, status) 上创建另一个索引并将连接条件更改为:

gwt.zone = 1 and status >= '1' and status < '7'

这等效于您的列表,但它将允许执行引擎使用索引。

这可能足以修复查询。最后,您可以在 gws.csp 上放置一个索引,看看这是否加快了速度。

“csp”是一对一的关系吗?如果不是,您可能会遇到创建巨大结果集的查询的问题。

于 2012-08-20T18:07:28.687 回答
1

由于gws表的行数比其他表多两个数量级,因此这是需要关注的一个。如果你想设计你的索引来定位这个特定的查询,那么第一步很简单。也就是说,您需要在连接列 (gws.csp) 上添加一个索引,并确保在索引中包含所有选定的列 - gws.res 和 gws.line_no(?)。

以上应该可以显着提高查询速度。第二个问题是确保gwt表有一个索引,其状态为第一列。

于 2012-08-20T17:36:34.950 回答