Три таблиці:
product
: зі стовпцями: ( a, g, ...a_lot_more... )
a: PK, clustered
g: bit-column
main
: зі стовпцями: ( c, f, a, b, ...a_lot_more... )
c: PK, clustered
f: bit-column
(a, b): UQ
lookup
зі стовпцями: ( a, b, c, i )
(a, b): PK, clustered
a: FK to product(a)
c: UQ, FK to main(c)
i: bit-column
Я не можу знайти хороші індекси для приєднання:
FROM
product
JOIN
lookup
ON lookup.a = product.a
JOIN
main
ON main.c = lookup.c
WHERE
product.g = 1
AND
main.f = 1
AND
lookup.i = 1
AND lookup.b = 17
Я спробував індекс покриття, product (g, a, ...)
і він використовується, але не з вражаючими результатами.
Деякі комбінації індексів lookup
таблиці створюють плани виконання з об'єднанням індексів з невеликим підвищенням ефективності порівняно з попереднім планом.
Чи є якась очевидна комбінація, яку мені не вистачає?
Чи може допомогти переконструкція структури?
СУБД є MySQL 5.5, і всі таблиці використовують InnoDB.
Розміри столу:
product: 67K , g applied: 64K
main: 420K , f applied: 190K
lookup: 12M , b,i applied: 67K