UPDATE行ON UPDATE触发器,多表条件

时间:2015-02-09 20:50:41

标签: mysql database shopware

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

除了普通文章之外,还有那些有多种变体的文章,比如不同尺码的衬衫。它是XS,S,M,L和/或不同颜色的相同文章......但是有不同的订单号和可能不同的价格。

因此,在Shopware中,您有一个包含核心文章数据的表格,一个包含详细数据,另一个包含可能的价格数据。

具有多个变体的文章在articles表中设置了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。

我想要实现的目标如下:

  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))
  4. *我知道这不起作用,但希望它能描述我的内容

    怪癖:

    • s_articles_prices db
    • 可能有多个匹配项
    • 必须是通过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 ;
    

1 个答案:

答案 0 :(得分:0)

  • 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

我不会吝啬/提供代码,但我认为你应该能够轻松解决这个问题:)。