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

本文共 1092 字,大约阅读时间需要 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;

转载于:https://www.cnblogs.com/chen-lhx/p/3935574.html

你可能感兴趣的文章
Cocostudio学习笔记(4) LoadingBar+ TextField
查看>>
cxf和jboss eap 6.2版本号冲突
查看>>
ORACLE触发器具体解释
查看>>
IOS开发之SVN的使用
查看>>
Python学习之元组
查看>>
第三次作业
查看>>
quartz多任务调度+spring 实现
查看>>
Codeforces 97.B Superset
查看>>
noip2008 笨小猴
查看>>
洛谷P1459 三值的排序 Sorting a Three-Valued Sequence
查看>>
合并流
查看>>
Nosql数据库教程之初探MongoDB
查看>>
Orchard详解--第三篇 依赖注入之基础设施
查看>>
ASP.NET没有魔法——ASP.NET MVC路由
查看>>
莫烦RL-01小例子
查看>>
3.23下午
查看>>
UISegmentedControl
查看>>
学习layer和laydate的官方文档
查看>>
Cocoa Touch提供了哪几种Core Animation过渡类型?
查看>>
复利实验的感想
查看>>