Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2039431
  • 博文数量: 610
  • 博客积分: 11499
  • 博客等级: 上将
  • 技术积分: 5511
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-12 19:27
文章分类

全部博文(610)

文章存档

2016年(5)

2015年(18)

2014年(12)

2013年(16)

2012年(297)

2011年(45)

2010年(37)

2009年(79)

2008年(101)

分类:

2012-03-01 17:10:15

原文地址:mysql 触发器 作者:大隐隐于床

实现功能
当更新表1(name)的数据时,根据条件(name != 'lucifer'),将更新的数据插入表2(tmp)
 
1 建表
  1. create table name(name varchar(20));
  2. create table tmp(name varchar(20));

2 插入数据

  1. insert into name(name) values('leon');
  2. insert into name(name) values('lucifer');

3 建触发器

  1. DELIMITER //
  2. CREATE TRIGGER mt BEFORE UPDATE ON name FOR EACH ROW
  3. BEGIN
  4. if(old.name<>'lucifer') then
  5. INSERT INTO tmp set name=new.name;
  6. end if;
  7. END
  8. //

4 update数据,查看结果

结果1. name表中name字段值不为'lucifer',插入数据,结果正确.

  1. update name set name='len' where name='leon';

  2. select * from tmp;
  3. +------+
  4. | name |
  5. +------+
  6. | len |
  7. +------+
  8. 1 row in set (0.00 sec)

结果2. name表中name字段等于'lucifer',未插入数据,结果正确

  1. update name set name='aaa' where name='lucifer';

  2. select * from tmp;
  3. +------+
  4. | name |
  5. +------+
  6. | len |
  7. +------+
  8. 1 row in set (0.00 sec)

 

 

 

阅读(338) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~