【数据库测试】触发器的几个实例


触发器(Trigger)是数据库中的一种特殊的存储过程,它们会自动执行,通常是在INSERT、UPDATE或DELETE等特定数据库操作之前或之后。以下是几个触发器的实例:

1. 记录更新操作的触发器

DELIMITER //

CREATE TRIGGER LogUpdate
AFTER UPDATE ON employees
FOR EACH ROW
BEGIN
    INSERT INTO employee_changes (employee_id, change_date, old_value, new_value)
    VALUES (OLD.employee_id, NOW(), OLD.salary, NEW.salary);
END //

DELIMITER ;

这个触发器会在employees表的任何记录被更新后执行,将变更记录插入到employee_changes表中。

2. 检查新插入数据的触发器

DELIMITER //

CREATE TRIGGER CheckNewProduct
BEFORE INSERT ON products
FOR EACH ROW
BEGIN
    IF NEW.price <= 0 THEN
        SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Price must be greater than 0';
    END IF;
END //

DELIMITER ;

在向products表插入新记录之前,这个触发器会检查产品价格是否大于0,如果不是,则会阻止插入操作。

3. 自动更新余额的触发器

DELIMITER //

CREATE TRIGGER UpdateBalance
AFTER INSERT ON orders
FOR EACH ROW
BEGIN
    UPDATE accounts SET balance = balance - NEW.total_amount WHERE account_id = NEW.account_id;
END //

DELIMITER ;

每当orders表中插入新订单时,这个触发器会自动从关联的accounts表中减去订单的总金额。

4. 记录删除操作的触发器

DELIMITER //

CREATE TRIGGER LogDelete
BEFORE DELETE ON customers
FOR EACH ROW
BEGIN
    INSERT INTO customer_deletions (customer_id, deletion_date)
    VALUES (OLD.customer_id, NOW());
END //

DELIMITER ;

此触发器会在customers表中的记录被删除之前执行,将删除的顾客信息记录在customer_deletions表中。

5. 维护库存数量的触发器

DELIMITER //

CREATE TRIGGER MaintainInventory
BEFORE INSERT ON order_details
FOR EACH ROW
BEGIN
    DECLARE current_stock INT;
    SELECT stock INTO current_stock FROM inventory WHERE product_id = NEW.product_id;
    IF current_stock < NEW.quantity THEN
        SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Insufficient inventory';
    END IF;
END //

DELIMITER ;

在向order_details表插入新订单详情之前,这个触发器会检查库存是否足够,如果库存不足,则会阻止插入操作。

6. 自动设置用户最后登录时间的触发器

DELIMITER //

CREATE TRIGGER SetLastLogin
AFTER UPDATE ON users
WHERE COLUMNS(user_status) DO
BEGIN
    IF NEW.user_status = 'Active' THEN
        UPDATE users SET last_login = NOW() WHERE user_id = NEW.user_id;
    END IF;
END //

DELIMITER ;

users表中的用户状态被更新为“Active”时,这个触发器会将该用户的最后登录时间设置为当前时间。

请注意,触发器的具体语法可能会根据所使用的数据库系统(如MySQL、PostgreSQL、Oracle等)有所不同。在实际应用中,触发器的使用需要谨慎,因为不当的触发器设计可能会影响数据库性能或导致数据不一致。

  • 4
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值