我正在使用 Shopware,一件奇怪的事情让我发疯了:(所以我将首先解释问题所在。
除了普通的物品,还有多种款式的,比如不同尺寸的衬衫。这是 XS、S、M、L 和/或不同颜色的同一篇文章......但有不同的订单号和可能不同的价格。
因此,在 Shopware 中,您有一个包含核心商品数据的表格,一个包含详细信息数据和一个包含可能价格数据的表格。
具有多个变体的文章在文章表中设置了一个 configurator_set_id 字段和一个 main_detail_id 字段。我的问题是,我们有一家商店,里面有很多这些变体文章,而建立商店逻辑的人……可能喝醉了。如果变体文章的主要文章处于非活动状态(缺货、停用等),则整个变体文章不再可购买……没有回退到下一个变体,它仍在商店中,但你不能这样做什么都没有。
所以我想轻松一点,如果变体状态发生变化,只需更新文章......但这就是我的问题真正开始的地方。所以首先是表结构:
s_articles:
+----+--------+----------------+---------------------+
| id | active | main_detail_id | configurator_set_id |
+----+--------+----------------+---------------------+
s_articles_details:
+------+---------+-----------+
| id | active | articleID |
+------+---------+-----------+
s_articles_prices
+----+-----------+-----------------+-------+
| id | articleID | articledetailID | price |
+----+-----------+-----------------+-------+
为了构建文章,Shopware 基本上从 s_articles 中获取数据,将它们与 s_articles_details 中的数据连接起来,其中 id = s_articles.main_details_id。
我试图达到的目标如下:
- 如果 s_articles_details 已更新,则获取已更新行的 id。
- 检查 id 是否对应 s_articles 表中的一个 main_detail_id
- 如果确实更新了该行,则设置 main_detail_id = (s_articles_prices.articledetailID WHERE s_articles_prices.articleID = id AND min(s_articles_prices.price))
*我知道这行不通,但希望它能描述我所说的
怪癖:
- s_articles_prices 数据库中可能有多个匹配项
- 它必须是通过 s_articles_details 表确定的有效变体/价格
任何帮助或朝着正确的方向推动将不胜感激(虽然我尽量不把头撞到墙上......)
编辑:最终解决方案
jean-françois-savard为我指明了正确的方向,因此我想出了以下解决方案:
DELIMITER $$
CREATE TRIGGER update_maindetailid_after_update AFTER UPDATE ON s_articles_details
FOR EACH ROW
BEGIN
DECLARE ArticleDetailID INT(11);
SELECT p.articledetailsID
INTO ArticleDetailID
FROM s_articles_prices p, s_articles_details d
WHERE p.articleID = NEW.articleID
AND d.id = p.articledetailsID
AND d.active
ORDER BY p.price, d.ordernumber ASC
LIMIT 1;
IF ArticleDetailID <> "" THEN
UPDATE s_articles SET s_articles.main_detail_id = ArticleDetailID
WHERE s_articles.id = NEW.articleID
AND s_articles.main_detail_id <> ArticleDetailID;
END IF;
END$$;
DELIMITER ;