是的,MySQL数据库触发器可以跨表操作。触发器是与表事件(如INSERT、UPDATE或DELETE)相关联的存储过程,当事件发生时,触发器会自动执行一些操作。触发器可以访问与触发事件相关的数据,并且可以在同一个数据库中的其他表上执行操作。
例如,假设你有两个表:orders
和order_summary
。当你在orders
表中插入一条新记录时,你可能希望更新order_summary
表以反映新的订单数量和总金额。这就需要使用跨表操作。
以下是一个简单的示例,展示了如何创建一个触发器来实现这个功能:
DELIMITER //
CREATE TRIGGER update_order_summary
AFTER INSERT ON orders
FOR EACH ROW
BEGIN
UPDATE order_summary
SET total_orders = total_orders + 1,
total_amount = total_amount + NEW.amount
WHERE order_summary.id = 1;
END;
//
DELIMITER ;
在这个示例中,我们创建了一个名为update_order_summary
的触发器,它在orders
表中插入新记录后触发。触发器将更新order_summary
表,增加订单数量和总金额。注意,我们使用了NEW
关键字来访问与触发事件相关的新记录的数据。