文档章节

mysql触发器使用

月下独酌100
 月下独酌100
发布于 2016/06/30 20:29
字数 463
阅读 31
收藏 2
a.准备表:
创建中间表
CREATE TABLE `testTriggerCount` (
      id int(32) not null,
      count int(32) not null
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into testTriggerCount(id,count) values(1,1);
create table testabc as select * from jiraissue(jira的核心表)



b. 创建触发器test1,当testabc表有更新的时候,更新testTriggerCount表的id为1的count=count+1,触发器工作
 b1.DROP TRIGGER IF EXISTS `test1`;

 b2.创建触发器
 DELIMITER $$
 CREATE TRIGGER `test1` after
 update ON `testabc` FOR EACH ROW
 BEGIN
 IF NEW.issuestatus <> OLD.issuestatus && OLD.issuetype=5 && NEW.issuestatus='10007' THEN
 update testTriggerCount set count=count+1 where id=1;
     END IF;
  END$$
 DELIMITER ;

 b3.执行下面语句的时候,更新了testTriggerCount表
 update testabc set issuestatus='10007' where id=16095

c.无效的触发器,可以创建,但是当触发器被触发的时候会报错
 c1.创建触发器
 DELIMITER $$
 CREATE TRIGGER `test1` after
 update ON `testabc` FOR EACH ROW
 BEGIN
 IF NEW.issuestatus <> OLD.issuestatus && OLD.issuetype=5 && NEW.issuestatus='10007' THEN
  update testabc set assignee='abc' where id in (select distinct source from issuelink where destination=OLD.id);
     END IF;
  END$$
 DELIMITER ;

 c2. 创建触发器test1
 DELIMITER $$
 CREATE TRIGGER `test1` before
 update ON `testabc` FOR EACH ROW
 BEGIN
 IF NEW.issuestatus <> OLD.issuestatus && OLD.issuetype=5 && NEW.issuestatus='10007' THEN
 update testabc set issuestatus='10007' where  id in (select distinct source from issuelink where destination=OLD.id);
     END IF;
  END$$
 DELIMITER ;

 c3.当创建上面的任何一个触发器之后,
  执行update  testabc set issuestatus='10007' where id=16095

  会报出下面的错误:
   19:52:26    update jira.testabc set issuestatus='10007' where id=16095
   Error Code: 1442.
   Can't update table 'testabc' in stored function/trigger because it is
   already used by statement which invoked this stored function/trigger.


d.下面这种触发器,只更新受影响的列,是可以的
 d1. 触发器1
 DELIMITER $$
 CREATE TRIGGER `test1` before
 update ON `testabc` FOR EACH ROW
 BEGIN
 IF NEW.issuestatus <> OLD.issuestatus && OLD.issuetype=5 && NEW.issuestatus='10007' THEN
  set new.assignee='abc';
     END IF;
  END$$
 DELIMITER ;

 d2. 触发器1
 DELIMITER $$
 CREATE TRIGGER `test1` before
 update ON `testabc` FOR EACH ROW
 BEGIN
 IF NEW.issuestatus <> OLD.issuestatus && OLD.issuetype=5 && NEW.issuestatus='10007' THEN
  set NEW.issuestatus='111';
     END IF;
  END$$
 DELIMITER ;

 d3.操作下面语句,触发触发器生效
update testabc set issuestatus='10007' where id=16095


参考:
https://www.sitepoint.com/how-to-create-mysql-triggers/
http://stackoverflow.com/questions/15300673/mysql-error-cant-update-table-in-stored-function-trigger-because-it-is-already

© 著作权归作者所有

共有 人打赏支持
月下独酌100
粉丝 26
博文 220
码字总数 56475
作品 0
浦东
高级程序员
私信 提问
MySQL的触发器

触发器—trigeer是数据库下用于监视数据改变的某种情况,并触发执行某种操作的一个功能,简单来说就是对某一张表符合某种条件的更改前或者后执行一段存储过程。在这里就简单的说一说在MySQL...

往事_Jim_遗
01/08
0
0
mysql-之触发器_已迁移

mysql 触发器 当发生某个事件(增删更查)时可以执行定义的sql语句 ===============总结 无情的分隔线 总结======================== 一、触发器作用 MySQL包含对触发器的支持。触发器是一种与...

鬼谷子灬
2016/06/29
14
0
记一次由mysql触发器引发的故障

上周六到公司上班,刚坐下没多久,公司业务传过消息说,用户borrow表信息无法更新。查看网站报错如下: 报错信息表示是由于mysql的函数和触发器引起的,问了下公司开发,他们表示函数功能已经...

Tyrant0532
10/29
0
0
《MySQL必知必会》读书笔记(四) 22~30章 完结篇

1、视图 视图不包含表中应该有的任何列或数据,它包含的是一个SQL查询。在视图创建之后,可以用于表基本相同的方式利用它们。可以对视图执行SELECT操作,过滤和排序数据,将视图联结到其他视...

一万
2016/02/08
329
0
MySQL触发器trigger的使用

Q:什么是触发器? A:   触发器是与表有关的数据库对象,在满足定义条件时触发,并执行触发器中定义的语句集合。 触发器的特性:   1、有begin end体,begin end;之间的语句可以写的简单...

zsdnr
2017/07/21
0
0

没有更多内容

加载失败,请刷新页面

加载更多

《农民的终结》读书笔记优秀范文2700字

《农民的终结》读书笔记优秀范文2700字: 《农民的终结》这本书分为两个部分,第一部分阐释了传统农民社会的逻辑和结构的严密性,在这样完整的社会结构面前,任何的变革都是不被农民欢迎的;...

原创小博客
15分钟前
0
0
序列化与反序列化实现

一、序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化。 把字节序列恢复为对象的过程称为对象的反序列化。 对象序列化之后得到的字节序列,主要有两种用途:   1) 把对...

狼王黄师傅
33分钟前
2
0
Spring boot 各种常用注解总结(不断完善中)

@Configuration把一个类作为一个IoC容器,它的某个方法头上如果注册了@Bean,就会作为这个Spring容器中的Bean。 @Scope注解 作用域 @Lazy(true) 表示延迟初始化 @Service用于标注业务层组件、...

覃大光
35分钟前
2
1
spring学习笔记(二)spring 事件的使用

spring 中的事件 spring事件通过订阅发布 可以解耦操作 可以同步 可以异步 步骤 编写事件 通过继承org.springframework.context.ApplicationEvent 来编写事件 public ApplicationEvent(Obj...

NotFound403
昨天
16
0
特斯拉车主成功破解了自己Model 3汽车

据汽车博客Electrek消息,一位特斯拉车主成功破解了自己Model 3汽车,还在此基础上运行了Ubuntu。 这位叫trsohmers的网友表示,“功劳大多要归到Ingineerix的头上,他花了数月才找到初始的那...

linuxCool
昨天
6
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部