转载地址:http://www.2cto.com/database/201212/176781.html
触发器是MySQL响应以下任意语句而自动执行的一条MySQL语句(或位于BEGIN和END语句之间的一组语句): www.2cto.com
DELETE;
INSERT;
UPDATE;
使用触发器,需要MySQL5或之后的版本支持。
一、触发器基本操作
1、创建触发器
创建触发器时,需要给出4条信息:
唯一的触发器名;(虽然MySQL5允许不同的表上的触发器名称相同,但一般最好不要这么做。) www.2cto.com
触发器关联的表;
触发器响应的事件;
触发器何时执行;
语法结构:
create trigger trigger_name (BEFORE|AFTER) (delete|update|insert) on table_name
for each row
BEGIN
要触发的sql语句;
END;
示例:
[sql]
mysql> create trigger t_trig before insert on t_goods for each row
-> begin
-> set NEW.add_date = current_date();
-> end;
-> |
mysql> delimiter ;
mysql> insert into t_goods(id,goods_name,quantity)
-> values(1,'apple',50);
-> |
mysql> select * from t_goods;
-> |
+------+------------+----------+------------+
| id | goods_name | quantity | add_date |
+------+------------+----------+------------+
| 1 | apple | 50 | 2012-12-12 |
+------+------------+----------+------------+
2、删除触发器
DROP TRIGGER [schema_name.]trigger_name;
示例:
mysql> DROP TRIGGER t_trig;
3、查看触发器
SHOW TRIGGERS [ FROM DBNAME [ like '' ] ];
示例:
[sql] www.2cto.com
mysql> show triggers;
+---------+--------+---------+------------------------------------------------------------------------------------------
| Trigger | Event | Table | Statement
+---------+--------+---------+------------------------------------------------------------------------------------------
| t_trig | INSERT | t_goods | begin
set NEW.add_date = current_date();
end | BEFORE | NULL | | root@localhost | latin1 | latin1_swedish_ci | latin1_swedish_ci |
+---------+--------+---------+------------------------------------------------------------------------------------------
mysql> show triggers from test;
+---------+--------+---------+------------------------------------------------------------------------------------------
| Trigger | Event | Table | Statement
+---------+--------+---------+------------------------------------------------------------------------------------------
| t_trig | INSERT | t_goods | begin
set NEW.add_date = current_date();
end | BEFORE | NULL | | root@localhost | latin1 | latin1_swedish_ci | latin1_swedish_ci |
+---------+--------+---------+------------------------------------------------------------------------------------------
mysql> show triggers from test like 't%';
+---------+--------+---------+------------------------------------------------------------------------------------------
| Trigger | Event | Table | Statement
+---------+--------+---------+------------------------------------------------------------------------------------------
| t_trig | INSERT | t_goods | begin
set NEW.add_date = current_date();
end | BEFORE | NULL | | root@localhost | latin1 | latin1_swedish_ci | latin1_swedish_ci |
+---------+--------+---------+------------------------------------------------------------------------------------------
二、注意事项
1、只有表支持触发器,视图及临时表都不支持;
2、每个表最多支持6个触发器;
3、单一触发器不能与多个事件或多个表关联;
4、对于INSERT而言,新增的行用NEW来表示,行中的每一列的值,用NEW.列名来表示;
对于DELETE而言,删除的行用OLD来表示;
对于UPDATE而言,更新前的行用OLD来表示,更新后的行用NEW来表示
- 【数据库】9.0 MySQL入门学习(九)——获得数据库和表的信息、日期计算、查询、选择特殊列
1.0 SELECT语句用来从数据表中检索信息. SELECT what_to_select FROM which_table WHERE conditions_to_satisfy; what_to ...
- 【数据库】7.0 MySQL入门学习(七)——MySQL基本指令:帮助、清除输入、查询等
1.0 help == ? 帮助指令,查询某个指令的解释.用法.说明等.详情参考博文: [数据库]6.0 MySQL入门学习(六)——MySQL启动与停止.官方手册.文档查询 https://www. ...
- 【数据库】4.0 MySQL入门学习(四)——linux系统环境下MySQL安装
1.0 我的操作系统是CentOS Linux release 7.6.1810 (Core) 系统详细信息如下: Linux version 3.10.0-957.1.3.el7.x86_64 ( ...
- 【数据库】3.0 MySQL入门学习(三)——Windows系统环境下MySQL安装
1.0 我的操作系统是window10 专业版 64位.,不过至少windows7以上系统都是一样的. 关于MySQL如何下载,请参考博文: [数据库]2.0 如何获得MySQL以及MySQL安装 h ...
- 【转】MYSQL入门学习之十:视图的基本操作
转载地址:http://www.2cto.com/database/201212/176775.html 一.视图的基本介绍 www.2cto.com 视图是虚拟的表.与包含数据 ...
- 【数据库】2.0 MySQL入门学习(二)——如何获得MySQL以及MySQL安装
1.0 如何获得MySQL: www.oracle.com https://dev.mysql.com/downloads/ 2.0 例如进入Oracle官网,找到MySQL: 进入页面后,切换到“资 ...
- MYSQL数据库学习----索引和触发器
一:索引 索引是创建在数据库表上,其作用是提高对表中数据的查询速度. 假设数据库中有一张1000条记录的表格,如果没有创建索引的话,用户想通过查询条件查询,实际上是把整个数据库中1000条记录都读取一 ...
- 【转】MYSQL入门学习之十三:自定义函数的基本操作
转载地址:http://www.2cto.com/database/201212/177382.html 一.自定义函数(UDF)的特性和功能 www.2cto.com 函数能分 ...
- 【转】MYSQL入门学习之十二:存储过程的基本操作
转载地址:http://www.2cto.com/database/201212/177380.html 存储过程简单来说,就是为以后的使用而保存的一条或多条MySQL语句的集合.可将其视为批文件,虽 ...
随机推荐
- [Linux Tips] 1. 查看端口
查看监听的端口 # netstat -lnp
- 线段树 Interval Tree
一.线段树 线段树既是线段也是树,并且是一棵二叉树,每个结点是一条线段,每条线段的左右儿子线段分别是该线段的左半和右半区间,递归定义之后就是一棵线段树. 例题:给定N条线段,{[2, 5], [4, ...
- CheckBox的用法
if (window.pageConfig["IsCommend"] == "True") { $("#IsCommend").v ...
- 分布式领域CAP理论
分布式领域CAP理论,Consistency(一致性), 数据一致更新,所有数据变动都是同步的Availability(可用性), 好的响应性能Partition tolerance(分区容错性) 可 ...
- js方法和prototype
JS中的方法可以分为三类 1.对象方法 2.类方法 3.原型方法 例: function People(name) { this.name=name; //对象方法 this.Introduce=fu ...
- linux第2天 信号 wait
孤儿进程和僵尸进程 如果父进程先退出,子进程还没退出那么子进程的父进程将变为init进程.(注:任何一个进程都必须有父进程) 如果子进程先退出,父进程还没退出,那么子进程必须等到父进程捕获到了子进程的 ...
- css3:与背景的相关样式
1. (1)background-origin : border-box | padding-box | content-box;(设置元素背景图片的原始起始位置.) //需要注意的是,如果背景不是n ...
- linux扩大swap交换空间
有两种解决方法:一是创建新的swap分区;另一则是创建swap文件 创建swap文件如果你的硬盘空间已经全部分配给其他分区,也没有多余的预算新添购硬盘,我们可以利用swap文件的方式增加虚拟的swap ...
- mac tomcat
alampsdeMacBook-Pro:bin alamps$ ./startup.sh Using CATALINA_BASE: /Users/alamps/Library/apache-tomca ...
- java装饰者模式理解
java 装饰者模式其实就是扩展子类的功能,和继承是一个性质. 但继承是在编译时就固定扩展了父类的一些功能,而装饰者模式是在运行过程中动态绑定对象,实现一个子类可以随时扩展功能. 将方法排列组合,也可 ...