首页 > 解决方案 > 需要指导编写 MySQL 触发器

问题描述

我先承认,这是我的第一个 MySQL 触发器。MySQL 版本为 8.0。

我有一个订单和订单行项目表。在订单表中,我有一列存储所有行项目的总数。我需要一个触发器,每次为该订单添加或更改订单项时更新总数。这是我到目前为止所拥有的:

CREATE TRIGGER update_line_item_total
AFTER INSERT
   ON orderlines.price FOR EACH ROW

BEGIN

   -- variable declarations
   DECLARE li_order_id INT;
   DECLARE li_total DEC;

   SET li_order_id = orderlines.order_id; 
   SET li_total = SUM (orderlines.price) WHERE orderlines.order_id = li_order_id;

   -- trigger code
   UPDATE orders SET 
    total_lineitems = li_total
    WHERE orders.order_id = li_order_id;
END;

我将它放入 MySQL Workbench 并被拒绝。我知道 DECLARE 语句、第二个 SET 语句和 END 语句是标记为不正确的语句,但是我什至不知道在哪里可以找到问题所在。

寻求指导和方向。

谢谢,

迈克尔·弗兰克尔向导咨询集团公司

标签: mysqlmysql-workbench

解决方案


  1. 你的问题出在这一行: SET li_total = SUM (orderlines.price) WHERE orderlines.order_id = li_order_id;

  2. 添加分隔符。

做这个 :

delimiter |
CREATE TRIGGER update_line_item_total
AFTER INSERT
   ON orderlines.price FOR EACH ROW

BEGIN

   -- variable declarations
   DECLARE li_order_id INT;
   DECLARE li_total DEC;
   declare li_total_temp dec;

   SET li_order_id = orderlines.order_id; 
   select orderlines.price into li_total_temp  WHERE orderlines.order_id = li_order_id;
   SET li_total =  li_total + li_total_temp;

   -- trigger code
   UPDATE orders SET 
    total_lineitems = li_total
    WHERE orders.order_id = li_order_id;
END |
delimiter ;

推荐阅读