Chinaunix首页 | 论坛 | 博客
  • 博客访问: 457459
  • 博文数量: 42
  • 博客积分: 1325
  • 博客等级: 中尉
  • 技术积分: 1312
  • 用 户 组: 普通用户
  • 注册时间: 2009-01-13 18:00
个人简介

呵~~~呵~~~

文章分类

全部博文(42)

文章存档

2016年(3)

2015年(1)

2014年(2)

2013年(2)

2012年(7)

2011年(11)

2010年(3)

2009年(13)

我的朋友

分类: 数据库开发技术

2011-09-07 20:30:00

实现功能
当更新表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)

 

 

 

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