UPDATE 行 ON UPDATE 触发器,多 table 条件
UPDATE row ON UPDATE trigger, multi table condition
我正在使用 Shopware,一件奇怪的事情让我抓狂:( 所以我将首先解释问题是什么。
除了普通商品外,还有多种款式的商品,例如不同尺码的衬衫。这是同一件商品的 XS、S、M、L and/or 不同颜色...但订单号不同,价格可能也不同。
所以在 Shopware 中,您有一个 table 包含核心商品数据,一个包含详细信息数据,一个包含可能的价格数据。
具有多个变体的文章在文章 table 中设置了一个 configurator_set_id 字段和一个 main_detail_id 字段。我的问题是,我们有一家商店,里面有很多这些变体文章,而构建商店逻辑的人……可能喝醉了。如果变体文章的主要文章处于非活动状态(缺货、停用等),则整个变体文章不再可购买……没有退路到下一个变体,它仍在商店中,但您不能这样做任何东西。
所以我觉得随和,如果变体状态发生变化,只需更新文章...但这才是我的问题真正开始的地方。所以这里首先是 table 结构:
s_articles:
+----+--------+----------------+---------------------+
| id | active | main_detail_id | configurator_set_id |
+----+--------+----------------+---------------------+
s_articles_详情:
+------+---------+-----------+
| id | active | articleID |
+------+---------+-----------+
s_articles_价格
+----+-----------+-----------------+-------+
| id | articleID | articledetailID | price |
+----+-----------+-----------------+-------+
为了构建文章,Shopware 基本上从 s_articles 中获取数据,将它们与来自 s_articles_details 的数据结合起来,其中 id = s_articles.main_details_id.
我试图实现以下目标:
- 如果 s_articles_details 已更新,获取已更新行的 ID。
- 检查id是否对应s_articlestable
中的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 db
中可能有多个匹配项
- 它必须是一个活动的 variant/price,这是通过 s_articles_details table
确定的
我们将不胜感激向正确方向提供的任何帮助或推动(虽然我尽量不让自己的头撞到墙上...)
编辑:最终解决方案
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 ;
Trigger
是你需要的。
- 创建一个触发器,每次在
s_articles_details
上完成更新时都会触发该触发器
- 在触发器主体中使用
NEW
关键字引用新值。
- 根据新值,做你的条件,
update/insert
其他表中的正确值。
帮助您入门的代码段
DELIMITER $$
CREATE TRIGGER tr_au_s_articles_details AFTER UPDATE ON s_articles_details
FOR EACH ROW
BEGIN
-- Here you can access the id of the updated article New.id
-- update/insert depending on the condition of the newvalue.
-- Check if id corresponds to a main_detail_id in the s_articles table
-- Here an int : select count(id) from s_articles where main_detail_id = new.id
END;
DELIMITER ;
有关 Trigger
语法的详细信息,请参阅 documentation。
我不会 spoon/feed 代码,但我认为您现在应该能够轻松解决此问题:)。
我正在使用 Shopware,一件奇怪的事情让我抓狂:( 所以我将首先解释问题是什么。
除了普通商品外,还有多种款式的商品,例如不同尺码的衬衫。这是同一件商品的 XS、S、M、L and/or 不同颜色...但订单号不同,价格可能也不同。
所以在 Shopware 中,您有一个 table 包含核心商品数据,一个包含详细信息数据,一个包含可能的价格数据。
具有多个变体的文章在文章 table 中设置了一个 configurator_set_id 字段和一个 main_detail_id 字段。我的问题是,我们有一家商店,里面有很多这些变体文章,而构建商店逻辑的人……可能喝醉了。如果变体文章的主要文章处于非活动状态(缺货、停用等),则整个变体文章不再可购买……没有退路到下一个变体,它仍在商店中,但您不能这样做任何东西。
所以我觉得随和,如果变体状态发生变化,只需更新文章...但这才是我的问题真正开始的地方。所以这里首先是 table 结构:
s_articles:
+----+--------+----------------+---------------------+
| id | active | main_detail_id | configurator_set_id |
+----+--------+----------------+---------------------+
s_articles_详情:
+------+---------+-----------+
| id | active | articleID |
+------+---------+-----------+
s_articles_价格
+----+-----------+-----------------+-------+
| id | articleID | articledetailID | price |
+----+-----------+-----------------+-------+
为了构建文章,Shopware 基本上从 s_articles 中获取数据,将它们与来自 s_articles_details 的数据结合起来,其中 id = s_articles.main_details_id.
我试图实现以下目标:
- 如果 s_articles_details 已更新,获取已更新行的 ID。
- 检查id是否对应s_articlestable 中的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 db 中可能有多个匹配项
- 它必须是一个活动的 variant/price,这是通过 s_articles_details table 确定的
我们将不胜感激向正确方向提供的任何帮助或推动(虽然我尽量不让自己的头撞到墙上...)
编辑:最终解决方案
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 ;
Trigger
是你需要的。- 创建一个触发器,每次在
s_articles_details
上完成更新时都会触发该触发器
- 在触发器主体中使用
NEW
关键字引用新值。 - 根据新值,做你的条件,
update/insert
其他表中的正确值。
帮助您入门的代码段
DELIMITER $$
CREATE TRIGGER tr_au_s_articles_details AFTER UPDATE ON s_articles_details
FOR EACH ROW
BEGIN
-- Here you can access the id of the updated article New.id
-- update/insert depending on the condition of the newvalue.
-- Check if id corresponds to a main_detail_id in the s_articles table
-- Here an int : select count(id) from s_articles where main_detail_id = new.id
END;
DELIMITER ;
有关 Trigger
语法的详细信息,请参阅 documentation。
我不会 spoon/feed 代码,但我认为您现在应该能够轻松解决此问题:)。