Prestashop ソリューションを使用してレイヤード ナビゲーション モジュールに取り組んでいます。実行する tmp テーブルを作成する Sql クエリを最適化し、この方法で mysql にボトルネックを作成しようとしています。
これはクエリです:
SELECT p.*, p.id_category_default, pl.available_later, pl.description_short, pl.link_rewrite, pl.name, i.id_image, il.legend, m.name manufacturer_name, DATEDIFF(p.`date_add`, DATE_SUB(NOW(), INTERVAL 30 DAY)) > 0 AS new
FROM `ps_category_product` cp
LEFT JOIN ps_category c ON (c.id_category = cp.id_category)
LEFT JOIN `ps_product` p ON p.`id_product` = cp.`id_product`
LEFT JOIN ps_product_lang pl ON (pl.id_product = p.id_product)
LEFT JOIN ps_image i ON (i.id_product = p.id_product AND i.cover = 1)
LEFT JOIN ps_image_lang il ON (i.id_image = il.id_image AND il.id_lang = 2)
LEFT JOIN ps_manufacturer m ON (m.id_manufacturer = p.id_manufacturer)
WHERE p.`active` = 1 AND c.nleft >= 2 AND c.nright <= 29 AND c.active = 1 AND pl.id_lang = 2
AND p.id_product IN (74,78,130,146,168,169,178,195,...,297,302,1986,1987,1988,1993,1999,2000,2001)
GROUP BY p.id_product ORDER BY p.date_upd desc LIMIT 0,48
GROUP BY が原因で tmp テーブルが作成されることはわかっていますが、それを削除する方法がわかりません。同じプロセスが SQL ではなく PHP で実行できれば、解決策になる可能性があります。
前もって感謝します。