9.触发器的操作

9.触发器的操作

为什么使用触发器

触发器是mysql的数据库对象之一,该对象与编程语言中的函数非常相似,需要声明、执行等。但是触发器的执行不是由程序调用,也不是由手工启动,而是由事件激活而实现执行。

  • 在学生表中拥有字段学生名字,字段学生总数,每当添加一条关于学生记录时,学生表的总数就必须同时改变。
  • 在顾客信息表中拥有字段顾客名字,字段顾客的电话和字段顾客的地址缩写,每当添加一条关于顾客记录时,都需要检查电话号码格式是否正确,顾客地址缩写是否正确。

上述实例虽然所需要实现的业务逻不同,但是都需要在表发生更改时自动进行一些处理。这是可以使用触发器处理数据库对象。

创建触发器

创建一条有执行语句的触发器:

creata trigger trigger_name
    BEFORE|AFTER trigger_EVENT
        ON TABLE_NAME FOR EACH ROW trigger_STMT

上述语句中,trigger_name 参数表示所需要创建的触发器名字,在具体创建触发器时,触发器标识符不能与已经存在的触发器重复。除了上述要求外,建议触发器命名(标识符)为trigger_xxx或者tri_xxx;BEFORE和AFTER参数指定了触发器执行的时间;trigger_EVENT是指触发事件,包含DELETE,INSERT和UPDATE语句;TABLE_NAME参数表示触发器事件操作表的名字;FOR EACH ROW参数表示任何一条记录上的操作满足触发事件都会触发该触发器;trigger_STMT参数表示激活触发器后被执行的语句;

具体操作

创建一条有执行语句的触发器:

CREATE TRIGGER tri_diarytime
    BEFORE INSERT
        ON t_dept FOR EACH ROW
            INSERT INTO t_diary VALUES(NULL,'t_dept',now());

创建包含多条执行语句的触发器:

CREATE trigger tri_diarytime2
    AFTER INSERT
        ON t_dept FOR EACH ROW
            BEGIN 
                INSERT INTO t_diary VALUES(NULL,'t_dept',NOW());
                INSERT INTO t_diary VALUES(NULL,'t_dept',NOW());
              END

查看触发器

可以使用SHOW TRIGGERS;语句对触发器进行查看

删除触发器

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值