Trzy stoły:
product
: z kolumnami: ( a, g, ...a_lot_more... )
a: PK, clustered
g: bit-column
main
: z kolumnami: ( c, f, a, b, ...a_lot_more... )
c: PK, clustered
f: bit-column
(a, b): UQ
lookup
z kolumnami: ( a, b, c, i )
(a, b): PK, clustered
a: FK to product(a)
c: UQ, FK to main(c)
i: bit-column
Nie mogę znaleźć dobrych indeksów dla złączenia:
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
Wypróbowałem indeks pokrycia product (g, a, ...)
i jest on używany, ale nie ze spektakularnymi wynikami.
Niektóre kombinacje indeksów w lookup
tabeli tworzą plany wykonania ze scalaniem indeksów, z niewielkim wzrostem wydajności w porównaniu z poprzednim planem.
Czy brakuje mi oczywistej kombinacji?
Czy ponowne zaprojektowanie konstrukcji może pomóc?
DBMS to MySQL 5.5, a wszystkie tabele używają InnoDB.
Rozmiary stołu:
product: 67K , g applied: 64K
main: 420K , f applied: 190K
lookup: 12M , b,i applied: 67K