您当前的位置: 首页 > 数据库教程 > MySQL教程 > mysql触发器实例

mysql触发器实例

作者:不详 来源:网络 发布时间: 2014-07-17 09:05 点击:
测试表1 ? 1 2 3 4 5 6 7 8 DROP TABLE IF EXISTS test; CREATE TABLE test ( id bigint(11) unsigned NOT NULL AUTO_INCREMENT, name varchar(100) NOT NULL DEFAULT '', type varchar(100), create_time datetime, PRIMARY KEY (ID) ) ENGINE=InnoDB AUTO_INCREMENT=

mysql触发器实例

  测试表1

  ?

  

  

  

  

  

  

  

  


  1

  2

  3

  4

  5

  6

  7

  8

  


  DROP TABLE IF EXISTS test;            

  CREATE TABLE test (

  id      bigint(11) unsigned NOT NULL AUTO_INCREMENT,

  name    varchar(100) NOT NULL DEFAULT '',

  type    varchar(100),

  create_time datetime,

  PRIMARY KEY (ID)

  ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

  


  测试表2

  ?

  

  

  

  

  

  

  

  


  1

  2

  3

  4

  5

  6

  7

  8

  9

  


  DROP TABLE IF EXISTS test_hisy;            

  CREATE TABLE test_hisy (

  id      bigint(11) unsigned NOT NULL AUTO_INCREMENT,

  name    varchar(100) NOT NULL DEFAULT '',

  type    varchar(100),

  create_time datetime,

  operation varchar(100) COMMENT '操作类型',

  PRIMARY KEY (ID)

  ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8;

  


  insert触发器

  表test新增记录后,将type值为“1”的记录同时插入到test_hisy表中(AFTER INSERT:录入后触发, BEFORE INSERT:录入前触发)

  ?

  

  

  

  

  

  

  

  


  1

  2

  3

  4

  5

  6

  7

  8

  9

  10

  11

  


  DELIMITER //

  DROP TRIGGER IF EXISTS t_after_insert_test//

  CREATE TRIGGER t_after_insert_test

  AFTER INSERT ON test

  FOR EACH ROW

  BEGIN

  IF new.type='1' THEN

  insert into test_hisy(name, type, create_time, operation)

  values(new.name, new.type, new.create_time, 'insert');

  END IF;

  END;//

  


  update触发器

  表test修改时,若type值为“2”则将修改前的记录同时插入到test_hisy表中(AFTER UPDATE:修改后触发, BEFORE UPDATE:修改前触发)

  ?

  

  

  

  

  

  

  

  


  1

  2

  3

  4

  5

  6

  7

  8

  9

  10

  11

  


  DELIMITER //

  DROP TRIGGER IF EXISTS t_before_update_test//

  CREATE TRIGGER t_before_update_test

  BEFORE UPDATE ON test

  FOR EACH ROW

  BEGIN

  IF new.type='2' THEN

  insert into test_hisy(name, type, create_time, operation)

  values(old.name, old.type, old.create_time, 'update');

  END IF;

  END;//

  


  delete触发器

  表test删除记录前,将删除的记录录入到表test_hisy中(AFTER DELETE:删除后触发, BEFORE DELETE:删除前触发)

  ?

  

  

  

  

  

  

  

  


  1

  2

  3

  4

  5

  6

  7

  8

  9

  


  DELIMITER //

  DROP TRIGGER IF EXISTS t_before_delete_test//

  CREATE TRIGGER t_before_delete_test

  BEFORE DELETE ON test

  FOR EACH ROW

  BEGIN

  insert into test_hisy(name, type, create_time, operation)

  values(old.name, old.type, old.create_time, 'delete');

  END;//

  


  注:以上触发器例子中出现的new为修改后的数据, old为修改前的数据
分享到:
本文"mysql触发器实例"由远航站长收集整理而来,仅供大家学习与参考使用。更多网站制作教程尽在远航站长站。
顶一下
(0)
0%
踩一下
(0)
0%
[点击 次] [返回上一页] [打印]
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价:
表情:
用户名: 密码: 验证码:
关于本站 - 联系我们 - 网站声明 - 友情连接- 网站地图 - 站点地图 - 返回顶部
Copyright © 2007-2013 www.yhzhan.com(远航站长). All Rights Reserved .
远航站长:为中小站长提供最佳的学习与交流平台,提供网页制作与网站编程等各类网站制作教程.
官方QQ:445490277 网站群:26680406 网站备案号:豫ICP备07500620号-4