mysql触发器入门级

1 触发器,达到条件发生改变时,触发的操作,触发器是针对行操作触发的。

创建触发器,

DELIMITER $$
CREATE TRIGGER trigger_name trigger_time trigger_event ON tb_name FOR EACH ROW trigger_stmt
$$
DELIMITER ;

详解:

DELIMITER $$:一般情况下,mysql默认是以 ; 作为结束语句,与触发器中需要的分行起冲突
为解决此问题可用DELIMITER,如:DELIMITER $$,可以将结束符号变成$$,当触发器创建完成后,可以用DELIMITER ;来将结束符号变成;
trigger_name:触发器的名称tirgger_time:触发时机,为BEFORE或者AFTER,BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后
trigger_event:触发事件,为INSERT、DELETE或者UPDATE
tb_name:在哪张表格上引发的触发的事件
FOR EACH ROW:表示在任何一条记录上的操作满足触发事件都会触发该触发器
trigger_stmt:触发器的程序体,可以是一条SQL语句或者是用BEGIN和END包含的多条语句

2触发器类型使用的


load data语句是将文件的内容插入到表中,相当于是insert语句,而replace语句在一般的情况下和insert差不多,但是如果表中存在primary 或者unique索引的时候,如果插入的数据和原来的primary key或者unique相同的时候,会删除原来的数据,然后增加一条新的数据,所以有的时候执行一条replace语句相当于执行了一条delete和insert语句。


3在执行体内(triggerstmt)声明变量

DECLARE var_name var_type [DEFAULT value] #定义变量,可指定默认值
SET var_name = value  #给变量赋值

4查看出发器

SHOW TRIGGERS,查看触发器信息,但不能查看指定触发器

查看指点触发器,select * from information_chema.triggers where TRIGGER_NAME='触发器名称'

5删除触发器

drop trigger 触发器名称;

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值