昨天处理了一则复杂关联SQL的优化,这类SQL的优化往往考虑以下四点:第一.查询所返回的结果集,通常查询返回的结果集很少,是有信心进行优化的;第二.驱动表的选择至关重要,通过查看执行计划,可以看到优化器选择的驱动表,从执行计划中的rows可以大致反映出问题的所在;第三.理清各表之间的关联关系,注意关联字段上是否有合适的索引;第四.使用straight_join关键词来强制表之间的关联顺序,可以方便我们验证某些猜想;SQL:执行时间:mysql> select c.yh_id,-> c.yh_dm,-> c.yh_mc,-> c.mm,-> c.yh_lx,-> a.jg_id,-> a.jg_dm,-> a.jg_mc,-> a.jgxz_dm,-> d.js_dm yh_js-> from a, b, c-> left join d on d.yh_id = c.yh_id-> where a.jg_id = b.jg_id-> and b.yh_id = c.yh_id-> and a.yx_bj = ‘Y’-> and c.sc_bj = ‘N’-> and c.yx_bj = ‘Y’-> and c.sc_bj = ‘N’-> and c.yh_dm = ’00693
...
继续阅读
(32)