博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
MySQL 触发器例子(两张表同步增加和删除)
阅读量:5858 次
发布时间:2019-06-19

本文共 1040 字,大约阅读时间需要 3 分钟。

以下两个例子来自:

http://www.cnblogs.com/nicholas_f/archive/2009/09/22/1572050.html
实测有效,但是原帖的分隔符不正确,因此稍作修改。
其中old表示tab2(被动触发),new表示tab1(主动触发,外部应用程序在此表里执行insert语句)

例子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 tab1
FOR EACH ROW
BEGIN
insert 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 ||  //mysql 默认结束符号是分号,当你在写触发器或者存储过程时有分号出现,会中止转而执行   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;

你可能感兴趣的文章
产品思想的重要性
查看>>
vtune 2015 安装
查看>>
Unity编辑器
查看>>
office 的VBA注册表信息
查看>>
协同过滤(ALS)
查看>>
ecmall如何添加新挂件
查看>>
PHP获取客户端和服务器IP地址
查看>>
将J2EE开发平台迁移到MAC上的日志及心得(三)-MySQL相关
查看>>
Tile Button
查看>>
MHRotaryKnob
查看>>
关于SQL_NO_CACHE
查看>>
断开SVN连接
查看>>
Python 3 基础
查看>>
STUN/TURN服务安装(for Kurento Media Server)
查看>>
CSS导航菜单简单示例
查看>>
Jenkins Ssh Connect Refuse
查看>>
iOS 多线程GCD
查看>>
spring mvc 任务定时器 @Scheduled
查看>>
DNS域名解析过程
查看>>
easyui data-options的使用
查看>>