mysql 触发器 的应用

例子 :当年龄大于18的时候能插入否者报错

delimiter //
create trigger age_tri before insert
on tri_test for each row
begin
    declare msg varchar(200); 
    if (new.age < 18) then  
        set msg = "Age must be greater than 18";    
            signal sqlstate 'LY000' SET message_text = msg;    
    end if;
end //
delimiter ;

解析:delimiter // 从新定义语句结束符为“//”

            create trigger age_tri 创建触发器age_tri 

            before insert  在插入之前

            begin  开始

            declare msg varchar(200) 声明变量为200个字符以内的msg

            if (new.age<18)then  判断条件为你想插入的数据<18爆出以下错误:

                         在报错的时候:ERROR 1644 (LY000): Age must be greater than 18

            end if; 结束判断

            end//  结束触发器

            delimiter ; 从新定义语句结束符为";"

用处:create [definer = { user | current_user}] trigger trigger_name 
            before|after        insert|update|delete
            on tbl_name 
            for each row 

 

查看触发器:
select * from information_schema.triggers ;

删除触发器:
drop trigger [if exists] [schema_name.]trigger_name;

注意:当你执行drop table时,表上的触发器也被drop掉了

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值