Я пытаюсь оптимизировать этот медленный запрос (> 2 с)
SELECT COUNT(*)
FROM crmentity c, mdcalls_trans_activity_update mtu, mdcalls_trans mt
WHERE (mtu.dept = 'GUN' OR mtu.dept = 'gun') AND
mtu.trans_code = mt.trans_code AND
mt.activityid = c.crmid AND
MONTH(mtu.ts) = 2 AND
YEAR(mtu.ts) = YEAR(NOW()) AND
c.deleted = 0 AND
c.smownerid = 28
Это вывод, когда я использую EXPLAIN:
id select_type table type possible_keys key key_len ref rows Extra
1 SIMPLE c index_merge PRIMARY,crmentity_smownerid_idx,crmentity_deleted_smownerid_idx,crmentity_smownerid_deleted_idx crmentity_smownerid_idx,crmentity_deleted_smownerid_idx 4,8 NULL 91 Using intersect(crmentity_smownerid_idx,crmentity_deleted_smownerid_idx); Using where; Using index
1 SIMPLE mt ref activityid activityid 4 pharex.c.crmid 60
1 SIMPLE mtu ref dept_idx dept_idx 5 const 1530 Using where
Он использует созданный мной индекс (dept_idx), но для выполнения запроса к набору данных из 1380384 записей все равно требуется более 2 секунд. Есть ли другой способ выразить этот запрос оптимальным образом?
ОБНОВЛЕНИЕ : Используя предложения Дэвида, запрос теперь сокращается до нескольких миллисекунд вместо того, чтобы выполняться более 2 секунд (фактически, 51 секунда в версии 5.0 MySQL).