SQL触发器

这里我们是说一下触发器 触发器也即触发程序 

触发器的英文是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表中的数据。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值