这里我们是说一下触发器 触发器也即触发程序
触发器的英文是trigger
触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。例如,下述语句将创建1个表和1个INSERT触发程序。触发程序将插入表中某一列的值加在一起:
mysql> CREATE TABLE account (acct_num INT, amount DECIMAL(10,2));
mysql> CREATE TRIGGER ins_sum BEFORE INSERT ON account
-> FOR EACH ROW SET @sum = @sum + NEW.amount;
首先我们了解一下触发器的语法:
create trigger trigger_name trigger_event
on tab_name for each row trigger_stmt
trigger_time是触发程序的动作时间。它可以是BEFORE或AFTER,以指明触发程序是在激活它的语句之前或之后触发。
trigger_event指明了激活触发程序的语句的类型。trigger_event可以是下述值之一:
· INSERT:将新行插入表时激活触发程序,例如,通过INSERT、LOAD DATA和REPLACE语句。
· UPDATE:更改某一行时激活触发程序,例如,通过UPDATE语句。
· DELETE:从表中删除某一行时激活触发程序,例如,通过DELETE和REPLACE语句。
tab_name 也就是你要操作的表
trigger_stmt 这是触发器触发的时候执行的语句
然后我们看一下两个表的数据create table one ( oneId int primary key, oneName varchar(20) ); create table two ( twoId int primary key, twoName varchar(20) ); delimiter | --这个是定界符 用于语句的结束 /*下面是创建了一个触发器 名叫oneTrigger 作用是在one表 其触发的动作是当one表出入数据的时候 它的执行触发程序的时间是执行完对one表的insert的操作的时候之后执行 下面的 twoName=new.oneName 的意思是twoName等于插入完成后的oneName的值 new.oneId同理 */ create trigger oneTrigger after insert on one for each row begin insert into two set twoName = new.oneName , twoId = new.oneId; end |
执行 select * from one; select * from two;
然后 看到
当我们执行下面这句insert语句的时候 触发器就开始执行
insert into one values (2 , 'A little Dog');
然后我们再看一下two表中的变化。
然后我们就可以看到执行触发器之后two表中的数据。