アプリの全文検索に Sphinx を使用しています。を使用しview
てテーブルからデータをフィルター処理し、products
Sphinx がこのビューにインデックスを付けます。現在、製品テーブルの下に関連するタグを含むハードコードされたフィールドがありますが、タグが変更される可能性があり、ハードコードされたフィールドを毎回操作する必要があるため、あまり良くありません。
したがって、GROUP_CONCAT を使用してビューを作成し、関連するすべてのタグを次のような構文でリストできると考えていました。
SELECT p.id AS id, GROUP_CONCAT(t.tag SEPARATOR '|') AS tags,
UNIX_TIMESTAMP(p.created) AS created
FROM products p
INNER JOIN products_tags pt ON pt.product_id = p.id
INNER JOIN tags t ON t.id = pt.tag_id
AND p.deleted = 0
AND (p.images IS NOT NULL OR p.images <> '')
AND p.status LIKE 'listed'
GROUP BY p.id;
このクエリの問題は、実行に時間がかかることです。本当に遅いです。1 つのレコードのみを取得するには、最大 5 秒かかります。これはEXPLAIN
出力です:
1, SIMPLE, pt, ALL, , , , , 165029, Using temporary; Using filesort
1, SIMPLE, p, eq_ref, PRIMARY, PRIMARY, 4, trych_default.pt.product_id, 1, Using where
1, SIMPLE, t, eq_ref, PRIMARY, PRIMARY, 4, trych_default.pt.tag_id, 1,
クエリを改善する方法や、私の問題に対するより良い解決策があるのではないかと思います。ありがとう!