mysql触发器语法及实例

本文介绍了MySQL触发器的基本语法和使用方法,并通过三个实例演示了如何创建不同条件下的触发器,以便于在插入新记录时自动执行某些操作。

mysql触发器:

1.语法:
create trigger trigger_name trigger_time  trigger_event on table_name for each row trigger_stmt

trigger_time:是触发动作时间,可以是before或者after
trigger_event:是触发语句类型,可以是insert ,update,delete
trigger_stmt:是触发之后需要做什么,如果是多个语句需要用begin  end

2.实例

示例一  
    delimiter //    
    create trigger InsertUser    
    before insert on user   
    for each row    
    Begin   
    insert into user_group(uid,gid) values(new.uid,'group4444444444');    
    end;//    
    delimiter ;  
  
     
示例二    
    delimiter //    
    create trigger InsertUser    
    before insert on user   
    for each row    
    Begin   
    IF new.Type=2 then   
    insert into user_group(uid,gid) values(new.uid,'group4444444444');    
    else   
    insert into user_group(uid,gid) values(new.uid,'group55555555555')    
    END IF;    
    end;//    
    delimiter ;
  
     
示例三:    
    delimiter //    
    create trigger InsertUser    
    before insert on user   
    for each row    
    Begin   
    IF new.type=1 then   
    insert into user_group(uid,gid) values(new.uid,'578d3369633b47bd9c1fe8bf905cbfb1');    
    END IF;    
    IF new.type=2 then   
     insert into user_group(uid,gid) values(new.uid,'387bcd57fc5a4c3c9de83ee210fef661');    
    END IF;    
    end;//    
    delimiter ;   


 

触发器(Trigger)是数据库中的一种特殊类型的存储过程,它在指定的表或视图上发生特定事件(如INSERT、UPDATE、DELETE)时自动执行。触发器通常用于维护数据完整性、审计数据更改或实现业务规则。 ### 一、触发器的基本语法(以MySQL为例) ```sql CREATE TRIGGER trigger_name {BEFORE | AFTER} {INSERT | UPDATE | DELETE} ON table_name FOR EACH ROW BEGIN -- 触发器逻辑 END; ``` #### 说明: - `trigger_name`:触发器名称。 - `{BEFORE | AFTER}`:指定触发器是在事件之前或之后执行。 - `{INSERT | UPDATE | DELETE}`:指定触发事件。 - `ON table_name`:指定作用的表。 - `FOR EACH ROW`:每行触发一次。 - `NEW` 和 `OLD`:引用新旧数据的关键字。 - `NEW`:用于INSERT和UPDATE操作,表示即将插入或更新的数据。 - `OLD`:用于UPDATE和DELETE操作,表示被更新或删除的数据。 --- ### 二、触发器实例 #### 实例1:记录员工信息变更日志 假设有一个 `employees` 表和一个 `employee_logs` 表。 ```sql CREATE TABLE employees ( id INT PRIMARY KEY, name VARCHAR(100), salary DECIMAL(10,2) ); CREATE TABLE employee_logs ( log_id INT AUTO_INCREMENT PRIMARY KEY, employee_id INT, old_salary DECIMAL(10,2), new_salary DECIMAL(10,2), change_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP ); ``` 创建一个 `AFTER UPDATE` 触发器,用于记录工资变动: ```sql DELIMITER // CREATE TRIGGER after_salary_update AFTER UPDATE ON employees FOR EACH ROW BEGIN IF OLD.salary != NEW.salary THEN INSERT INTO employee_logs (employee_id, old_salary, new_salary) VALUES (OLD.id, OLD.salary, NEW.salary); END IF; END // DELIMITER ; ``` #### 实例2:防止删除员工信息 ```sql DELIMITER // CREATE TRIGGER before_employee_delete BEFORE DELETE ON employees FOR EACH ROW BEGIN SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = '不允许删除员工记录'; END // DELIMITER ; ``` --- ### 三、触发器的优缺点 #### 优点: - 自动执行,确保数据一致性。 - 可用于审计和日志记录。 - 可以替代复杂约束。 #### 缺点: - 调试困难。 - 可能影响性能。 - 过度使用可能导致逻辑混乱。 --- ### 四、注意事项 - 不同数据库系统(如Oracle、SQL Server、PostgreSQL)的触发器语法略有不同。 - 触发器不应嵌套太深,避免逻辑复杂。 - 修改或删除触发器时应谨慎。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值