MySQL 触发器例子(两张表同步增加和删除)

来源:互联网 发布:万网域名赎回费用 编辑:程序博客网 时间:2024/06/08 16:20

例子1:
创建两个表,目的是在一个表里添加一条记录,另一个表也添加一条记录:

DROP TABLE IF EXISTS tab1;CREATE TABLE tab1(tab1_id varchar(11));DROP TABLE IF EXISTS tab2;CREATE TABLE tab2(tab2_id varchar(11));
创建触发器:t_afterinsert_on_tab1

作用:增加tab1表记录后自动将记录增加到tab2表中

delimiter || DROP TRIGGER IF EXISTS t_afterinsert_on_tab1 ||CREATE TRIGGER t_afterinsert_on_tab1 AFTER INSERT ON tab1FOR EACH ROWBEGINinsert into tab2(tab2_id) values(new.tab1_id);END||delimiter ;
测试:

INSERT INTO tab1(tab1_id) values('0001');
查看结果:

SELECT * FROM tab1;SELECT * FROM tab2;
例子2:

创建两个表,目的是在一个表里删除一条记录,另一个表也删除一条记录:

delimiter || DROP TRIGGER IF EXISTS t_afterdelete_on_tab1||CREATE TRIGGER t_afterdelete_on_tab1AFTER DELETE ON tab1FOR EACH ROWBEGINdelete from tab2 where tab2_id=old.tab1_id;END||
测试:

DELETE FROM tab1 WHERE tab1_id='0001';
看看结果

SELECT * FROM tab1;SELECT * FROM tab2;
例子3:

创建两个表,目的是在一个表里更新一条记录,另一个表也更新一条记录:

DELIMITER $$ CREATE TRIGGER `触发器名` BEFORE UPDATE ON `tab1` FOR EACH ROW BEGIN IF new.tab1_id=old.tab1_id THEN UPDATE `tab2` SET `tab2`.test=new.test WHERE `tab2`.tab2_id=old.tab1_id; END IF; END$$ DELIMITER ; 

0 0