数据库之——触发器(学习笔记)

徘徊边缘 提交于 2020-02-04 20:08:52


一、触发器的定义:
触发器(TRIGGER)是由事件来触发某个操作。这些事件包括INSERT语句、UPDATE语句和DELETE语句。当数据库系统执行这些事件时,会激活促发其执行相应的操作。

 

二、创建与使用触发器:
2.1创建只有一个执行语句的触发器

例:创建一个trig_book触发器,该触发器在表t_book插入一条数据后,对表t_bookType的bookNum数量对应的bookTypeId会自动加1

create trigger trig_book after insert 

           on t_book for each row 

                  update t_bookType set bookNum = bookNum+1 where new.bookTypeId = t_booktype.id;

INSERT INTO t_book VALUES(NULL,'java好',100,'ke',1);

t_book表:

t_bookType表:

 

2.1创建有多个执行语句的触发器

例子:

DELIMITER |   数据库语句   | DELIMITER;//告诉数据库这时一条语句内容

new   old   触发的两个过度变量;new:新增一条语句的新增对象;old:删除一条语句的删除对象;

DELIMITER |
create trigger trig_book2 after delete 
    on t_book for each row 
    begin 
          update t_bookType set bookNum = bookNum-1 where old.bookTypeId=t_booktype.id;
 
          insert into t_log values(null,NOW(),'在book表里删除了一条数据');
 
          delete from t_test where old.bookTypeId = t_test.id;
    end
|
DELIMITER ;
DELETE FROM t_book WHERE id=5;

三、查看触发器
3.1SHOWTRIGGERS 语句查看触发器信息

SHOW TRIGGERS;

3.2 在 triggers 表中查看触发器信息

DROP TRIGGER trig_book2 ;

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!