6表联合查询,有一个表数据有1万多,访问速度10多秒
我们要做一个查询是由6表数据联合显示的,现在有一个表1万多数据,每次刷新都要10多秒才显示,各位帮忙给点建议,怎么做优化好呢?
sql :
select com_cn_user.real_name,com_cn_client.clshortname,com_cn_product.skunum1,com_cn_product.arrival_cycle,com_cn_product.buy,com_cn_chuku_detail.id,com_cn_chuku_detail.sku,com_cn_product.itemnum,com_cn_product.color,com_cn_product.model,com_cn_product.title_cn,com_cn_product.brand,sum(com_cn_chuku_detail.quantity) as quantity,com_cn_chuku_detail.remark
from com_cn_chuku
left join com_cn_chuku_detail on com_cn_chuku.chukunum = com_cn_chuku_detail.chukunum
left join com_cn_product on com_cn_chuku_detail.itemnum = com_cn_product.itemnum
left join com_cn_supply on com_cn_supply.synum = com_cn_product.synum
left join com_cn_user on com_cn_user.usernum = com_cn_supply.usernum
left join com_cn_client on com_cn_client.clnum = com_cn_chuku.clnum
where com_cn_chuku.state=2 and com_cn_chuku.submit_date between '2012-1-1' and '2012-06-15' group by com_cn_product.itemnum order by null
explain:
id select_type table type possible_keys key key_len ref rows extra
1 simple com_cn_chuku all state null null null 177 using where; using temporary
1 simple com_cn_chuku_detail ref chukunum chukunum 4 com_backup.com_cn_chuku.chukunum 47
1 simple com_cn_product ref itemnum itemnum 47 com_backup.com_cn_chuku_detail.itemnum 1
1 simple com_cn_supply ref synum synum 32 com_backup.com_cn_product.synum 1
1 simple com_cn_user ref usernum usernum 38 com_backup.com_cn_supply.usernum 1
1 simple com_cn_client ref clnum clnum 32 com_backup.com_cn_chuku.clnum 2
------解决方案--------------------
有索引也不一定不扫全表……一下子说不清,hoho~~~~
如果仅针对目前的搜索方式,state,submit_date联合索引更佳