Puntualmente la jerarquía de ejecución sería mas o menos:
1. Indices PRIMARY.
2. Indices UNIQUE.
3. Indices INDEX y FULLTEXT.
Si quieres usar un índice definido sobre uno o más campos y que no sea un PRIMARY, debes incluir la cláusula FORCE INDEX nombreIndice en el FORM:
Código sql:
Ver originalSELECT SUM(cantidad)
FROM movimientos FORCE INDEX tipos
WHERE modelo='MADTE' AND fecha < '2009-01-01' AND tipo='E'
ORDER BY fecha ASC
Si cubre el campo principal del WHERE, entonces la consulta se acelera notablemente, pero todavía es optimizable.
A veces resulta conveniente que el índice definido sea uno que cubra la totalidad de los campos incluidos en el SELECT y al menos uno de ellos en el WHERE, de ese modo MySQL lee el índice y no la tabla.