MySQL触发器是一种特殊的存储过程,它在某个指定的事件发生时自动执行。这些事件包括INSERT、UPDATE和DELETE操作。触发器可以在这些事件发生之前(BEFORE)或之后(AFTER)执行。
假设我们有一个订单表orders
和一个订单日志表order_logs
,我们希望在每次插入新订单时,自动在订单日志表中记录一条日志。
-- 创建订单表
CREATE TABLE orders (
order_id INT AUTO_INCREMENT PRIMARY KEY,
customer_name VARCHAR(100),
order_date DATE
);
-- 创建订单日志表
CREATE TABLE order_logs (
log_id INT AUTO_INCREMENT PRIMARY KEY,
order_id INT,
log_message VARCHAR(255),
log_date TIMESTAMP DEFAULT CURRENT_TIMESTAMP
);
-- 创建AFTER INSERT触发器
DELIMITER $$
CREATE TRIGGER after_order_insert
AFTER INSERT ON orders
FOR EACH ROW
BEGIN
INSERT INTO order_logs (order_id, log_message)
VALUES (NEW.order_id, CONCAT('New order inserted with ID: ', NEW.order_id));
END$$
DELIMITER ;
通过以上信息,您应该对MySQL触发器有了全面的了解,并能够在实际应用中有效地使用它们。
领取专属 10元无门槛券
手把手带您无忧上云