您的位置:首页 > 数据库

SQL触发器

2015-11-04 21:42 211 查看
这里我们是说一下触发器 触发器也即触发程序

触发器的英文是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 |
然后我们看一下两个表的数据[/code]
执行
select * from one;
select * from two;

然后 看到









当我们执行下面这句insert语句的时候  触发器就开始执行

insert into one values (2 , 'A little Dog');

然后我们再看一下two表中的变化。





然后我们就可以看到执行触发器之后two表中的数据。


                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: