SQL触发器
2015-11-04 21:42
211 查看
这里我们是说一下触发器 触发器也即触发程序
触发器的英文是trigger
触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。例如,下述语句将创建1个表和1个INSERT触发程序。触发程序将插入表中某一列的值加在一起:
触发器的英文是trigger
触发程序是与表有关的命名数据库对象,当表上出现特定事件时,将激活该对象。例如,下述语句将创建1个表和1个INSERT触发程序。触发程序将插入表中某一列的值加在一起:
mysql> CREATE TABLE account (acct_num INT, amount DECIMAL(10,2));
mysql> CREATE TRIGGER ins_sum BEFORE INSERT ON account
-> FOR EACH ROW SET @sum = @sum + NEW.amount;
首先我们了解一下触发器的语法:
create trigger trigger_name trigger_event
on tab_name for each row trigger_stmt
trigger_time是触发程序的动作时间。它可以是BEFORE或AFTER,以指明触发程序是在激活它的语句之前或之后触发。 trigger_event指明了激活触发程序的语句的类型。trigger_event可以是下述值之一: · INSERT:将新行插入表时激活触发程序,例如,通过INSERT、LOAD DATA和REPLACE语句。 · UPDATE:更改某一行时激活触发程序,例如,通过UPDATE语句。 · DELETE:从表中删除某一行时激活触发程序,例如,通过DELETE和REPLACE语句。 tab_name 也就是你要操作的表
trigger_stmt 这是触发器触发的时候执行的语句
create table one ( oneId int primary key, oneName varchar(20) ); create table two ( twoId int primary key, twoName varchar(20) ); delimiter | --这个是定界符 用于语句的结束 /*下面是创建了一个触发器 名叫oneTrigger 作用是在one表 其触发的动作是当one表出入数据的时候 它的执行触发程序的时间是执行完对one表的insert的操作的时候之后执行 下面的 twoName=new.oneName 的意思是twoName等于插入完成后的oneName的值 new.oneId同理 */ create trigger oneTrigger after insert on one for each row begin insert into two set twoName = new.oneName , twoId = new.oneId; end |然后我们看一下两个表的数据[/code]
执行 select * from one; select * from two;
然后 看到
当我们执行下面这句insert语句的时候 触发器就开始执行
insert into one values (2 , 'A little Dog');
然后我们再看一下two表中的变化。
然后我们就可以看到执行触发器之后two表中的数据。
相关文章推荐
- mysql 5.7.9安装
- 小白学习做项目(2)_使用EntityFramework实现Code First设计数据库(2)
- mongodb 性能监控
- Mongodb sharding模式篇
- sql cookbook 笔录(一)
- [Database] Mysql数据库存储引擎
- MySQL乱码解决办法
- MySQL双主配置
- amoeba实现MySQL读写分离
- MySQL基本操作
- Mongodb replica set模式篇
- NOSQL的类型及其特点
- MySQL查询语句
- 数据库事务隔离级别
- Lnmp下安装memcached
- Mongodb主从模式篇
- Spark SQL利器:cacheTable/uncacheTable
- Oracle登录时提示错误,导致用户无法登录
- MySQL空间类型测试
- 数据库水平切分的实现原理解析