3つのテーブル:
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
テーブルのインデックスの組み合わせによっては、インデックスのマージを含む実行プランが作成され、以前のプランよりもわずかに効率が向上します。
私が見逃している明らかな組み合わせはありますか?
構造の再設計は役に立ちますか?
DBMSはMySQL 5.5であり、すべてのテーブルはInnoDBを使用しています。
テーブルサイズ:
product: 67K , g applied: 64K
main: 420K , f applied: 190K
lookup: 12M , b,i applied: 67K