1

那么问题来了......我想更新我的数据库中的库存表,其中包括

Sale(ProductID,Quantity,Price)                 
Invlevel(ProductID,Quantity)

我想为此更新使用触发器。我必须使用 2 个触发器(我认为)。1 在销售桌上,这将类似于

CREATE TRIGGER `sale_AINS` AFTER INSERT ON sale FOR EACH ROW
begin
update Invlevel set quantity = Invlevel.quantity-"sale.quantity" where
Invlevel.ProductID = "sale.ProductID";
END

有了这个触发器,当销售出现时,我想调整销售所涉及的产品的库存水平。但是,即使这个触发器没有错误并且在我插入到销售表时正常运行,它也不会在 Invlevel 表中进行任何更改,我不知道为什么( :@ )。

此外,我像这样在 Invlevel 表上进行了触发器

CREATE TRIGGER `invlevel_AUPD` after UPDATE on invlevel FOR EACH ROW
if invlevel.quantity < 20 
begin
insert into orders 
(select productid,amount from reorder where reorder.productid = invlevel.productid )
end

*(订单,重新排序是其他表)

它对我说我有语法错误,我不知道它是什么,即使我找到它,我什至无法检查逻辑,因为另一个触发器甚至没有工作......关于它的任何想法或帮助真的很有帮助。

4

1 回答 1

4

尝试

第一次触发

CREATE TRIGGER sale_AINS
AFTER INSERT ON sale 
FOR EACH ROW
  UPDATE invlevel 
     SET quantity = quantity - NEW.quantity
   WHERE productid = NEW.productid;

在此触发器中,您不需要BEGIN END阻止,因为只有一个语句。为了访问要插入的列值或行,您需要使用NEW关键字。

而第二个

DELIMITER $$
CREATE TRIGGER invlevel_AUPD
AFTER UPDATE ON invlevel 
FOR EACH ROW
BEGIN
  IF NEW.quantity < 20 THEN 
    INSERT INTO orders (productid, amount)
    SELECT productid, amount 
      FROM reorder 
     WHERE productid = NEW.productid;
  END IF;
END$$
DELIMITER ;

在第二个触发器IF中,语句超出了BEGIN END块并且 for 的语法IF错误。应该是IF ... THEN ... END IF;NEW关键字也有同样的问题。

这是SQLFiddle演示

您可以将您的IF条件放入WHERE子句并使其更简洁

CREATE TRIGGER invlevel_AUPD
AFTER UPDATE ON invlevel 
FOR EACH ROW
  INSERT INTO orders (productid, amount)
  SELECT productid, amount 
    FROM reorder 
   WHERE productid = NEW.productid
     AND NEW.quantity < 20;

这是更新的SQLFiddle演示

于 2013-06-01T18:24:57.990 回答