mysql - UPDATE row ON UPDATE 触发器,多表条件

标签 mysql database shopware

我正在使用 Shopware,一件奇怪的事情让我抓狂 :( 所以我将首先解释问题是什么。

除了普通商品外,还有多种款式的商品,例如不同尺码的衬衫。这是 XS、S、M、L 和/或不同颜色的同一商品……但订单号不同,价格可能也不同。

因此,在 Shopware 中,您有一个包含核心商品数据的表格,一个包含详细信息数据,一个包含可能的价格数据。

具有多个变体的文章在文章表中设置了一个 configurator_set_id 字段和一个 main_detail_id 字段。我的问题是,我们有一家商店,里面有很多这些变体文章,而构建商店逻辑的人……可能喝醉了。如果变体文章的主要文章处于非事件状态(缺货、停用等),则整个变体文章不再可购买……没有退路到下一个变体,它仍在商店中,但您不能这样做任何东西。

所以我觉得随和,如果变体状态发生变化,只需更新文章...但这才是我的问题真正开始的地方。所以首先是表结构:

文章:

+----+--------+----------------+---------------------+  
| 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。

我试图实现以下目标:

  1. 如果 s_articles_details 已更新,则获取已更新行的 ID。
  2. 检查id是否对应s_articles表中的main_detail_id
  3. 如果确实更新了行,则设置 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 ;

最佳答案

  • Trigger 是您需要的。
  • 创建一个触发器,每次在 s_articles_details 上完成更新时都会触发该触发器
  • 在触发器主体中使用 NEW 关键字引用新值。
  • 根据新值,做你的条件,并更新/插入其他表中的正确值。

帮助您入门的代码段

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 ;

参见 documentation有关 Trigger 语法的更多信息。

我不会勺子/喂代码,但我认为你现在应该能够轻松解决这个问题:)。

关于mysql - UPDATE row ON UPDATE 触发器,多表条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28419094/

相关文章:

php - WooCommerce 在前端自定义日期后显示产品总销售额

mysql - 实现从提供的日志到所需的比较形式的转换的最快查询是什么?

php - Shopware 5.2.11 在我的插件中包含 JavaScript

php - 需要一些有关通过 CSV 导入订单的 Mysql 帮助和建议

MySql,它是一种导出/导入从日期到日期的数据的方法吗?

mysql - mysql表中的排名条目

java - 连接到不同服务器中的多个数据库

mysql - 错误 2003 (HY000) : Can't connect to MySQL server on 'localhost' (10061)

php - Shopware 6 中嵌套 LineItem 的用例是什么?

stripe-payments - 如何在shopware 6中使用store-api设置付款详细信息