SQL - 触发器

  • 触发器是在插入、更新和删除语句前后自动执行的一堆SQL代码,但是触发器被触发后只会执行一次,通常我们使用触发器增强数据的一致性。

  • 创建触发器
    *

    sql 复制代码
    -- 创建触发器
    drop trigger if exists payments_after_insert;
    delimiter $$
    -- 在 payments表 insert 之后 触发 
    create trigger payments_after_insert
    	after insert on payments
        for each row 	-- 作用于受影响的每一行
    begin
    	update invoices
        set payment_total=payment_total + new.amount
        where invoice_id = new.invoice_id;
    end $$
    delimiter ;
    
    insert into payments
    values(default,5,3,'2019-01-01',10,1);
    select *
    from invoices;
    
    -- delete
    drop trigger if exists payments_after_delete;
    delimiter $$
    create trigger payments_after_delete
    	after delete on payments
        for each row
    begin
    	update invoices
        set payment_total=payment_total-old.amount
        where invoice_id=old.invoice_id;
    end$$
    delimiter ;
    
    delete 
    from payments
    where invoice_id=3;
  • 查看触发器

    • show triggers like'payments%'
  • 使用触发器进行审计

    • 触发器另一个常见用途,为了 审计的目的 而 记录对数据库的修改
    sql 复制代码
    drop trigger if exists payments_after_insert;
    delimiter $$
    -- 在 payments表 insert 之后 触发 
    create trigger payments_after_insert
    	after insert on payments
        for each row 	-- 作用于受影响的每一行
    begin
    	update invoices
        set payment_total=payment_total + new.amount
        where invoice_id = new.invoice_id;
        
        insert into payments_audit		-- 审计记录
        values(new.client_id,new.date,new.amount,'insert',now());
    end $$
    delimiter ;
    
    
    drop trigger if exists payments_after_delete;
    delimiter $$
    create trigger payments_after_delete
    	after delete on payments
        for each row
    begin
    	update invoices
        set payment_total=payment_total-old.amount
        where invoice_id=old.invoice_id;
        
        insert into payments_audit		-- 审计记录
        values(old.client_id,old.date,old.amount,'delete',now());
    end$$
    delimiter ;
    
    
    insert into payments
    values(default,5,3,'2019-01-01',10,1);
    select *
    from invoices;
    
    delete 
    from payments
    where invoice_id=3;
    
    SELECT * FROM payments_audit;	-- 查询审计记录表
相关推荐
折哥的程序人生 · 物流技术专研2 小时前
Java面试85题图解版 · 特别篇:2026后端高频面试题复盘(算法底层逻辑+高并发架构设计全解析,附Java实战代码)
java·网络·数据库·算法·面试
AOwhisky2 小时前
Redis 学习笔记(第三期):持久化与主从复制
运维·数据库·redis·笔记·学习·云计算
李白的天不白2 小时前
数据库连接报错问题
数据库
一条泥憨鱼3 小时前
【Redis】数据类型和常用命令
java·数据库·redis·后端·缓存
爱喝水的鱼丶3 小时前
SAP-ABAP:SAP视图开发入门:四类标准视图的适用场景与创建步骤详解
服务器·数据库·性能优化·sap·abap
大白要努力!4 小时前
MySQL 8.0 + Navicat 完整操作指南
数据库·mysql
云絮.5 小时前
数据库操作
数据库·mysql·算法·oracle
小小工匠5 小时前
Redis 缓存替换策略:8 种淘汰策略与 LRU 实现剖析
数据库·redis·缓存
小小龙学IT7 小时前
Go 泛型深度解析:从设计哲学到工程实践
服务器·数据库·golang