MYSQL触发器学习笔记
课程学至金色晨曦科技公司技术总监沙利穆
触发器
1. 什么是触发器
触发器是一种特殊类型的存储过程,不由用户直接调用。创建触发器时会对其进行定义,以便在对特定表或列作特定类型的数据修改时执行。
触发器从本质上来说,是一个存储过程,但是它与普通的存储过程不一样的地方在于,普通的存储过程是通过CALL方法进行调用的,而触发器不是用CALL调用,触发器是在我们提前设定好的事件出现以后,自动被调用的。
2.为什么要用触发器
我们在MySQL 5.0中包含对触发器的支持是由于以下原因:
(1)MySQL早期版本的用户长期有需要触发器的要求。
(2)我们曾经许诺支持所有ANSI标准的特性。
(3)您可以使用它来检查或预防坏的数据进入数据库。
(4)您可以改变或者取消INSERT, UPDATE以及DELETE语句。
(5)您可以在一个会话中监视数据改变的动作。在这里我假定大家都读过"MySQL新特性"丛书的第一集--"MySQL存储过程",那么大家都应该知道MySQL至此存储过程和函数,那是很重要的知识,因为在触发器中你可以使用在函数中使用的语句。特别举个例子:
①复合语句(BEGIN / END)是合法的.
②流控制(Flow-of-control)语句(IF, CASE, WHILE, LOOP, WHILE, REPEAT, LEAVE,ITERATE)也是合法的.
③变量声明(DECLARE)以及指派(SET)是合法的.
④允许条件声明.
⑤异常处理声明也是允许的.
⑥但是在这里要记住函数有受限条件:不能在函数中访问表.
因此在函数中使用以下语句是非法的。
ALTER 'CACHE INDEX' CALL COMMIT CREATE DELETE
DROP 'FLUSH PRIVILEGES' GRANT INSERT KILL
LOCK OPTIMIZE REPAIR REPLACE REVOKE
ROLLBACK SAVEPOINT 'SELECT FROM table'
'SET system variable' 'SET TRANSACTION'
SHOW 'START TRANSACTION' TRUNCATE UPDATE
在触发器中也有完全一样的限制.触发器相对而言比较新,因此会有(bugs)缺陷.所以我在这里给大家警告,就像我在存储过程书中所说那样.不要在含有重要数据的数据库中使用这个触发器,如果需要的话在一些以测试为目的的数据库上使用,同时在你对表创建触发器时确认这些数据库是默认的。
2.1 触发器的主要用途
触发器主要用于在多个有相互关系的表之间,做一些相互关联的操作。
2.2 临时表
更新:更新是用一条新的数据 替换一条旧的数据。在系统中,更新操作分为以下2个步骤:
(1)首先,把旧的数据删掉
(2)把新的数据插入表中。
在进行以上两个步骤之前,系统又进行了3个步骤:
(1) 系统创建两张临时表,临时表与要操作的表的结构完全相同,仅是结构相同,但是临时表中并无数据。
(2) 系统向其中一张临时表插入要更新的数据,
(3) 系统把要删除的,即要被更新的数据,插入另外一张临时表当中。
2.2.1 临时表的叫法:
NEW:用来插入新数据的临时表
OLD:数据要被替换的临时表
2.2.2 临时表的使用
NEW 列名获取插入值
2.2.3 使用不同的语句与使用临时表的关系
使用UPDATA语句:可以使用NEW和OLD两张临时表
使用INSERT语句:只能使用NEW临时表
使用DELETE语句:只能使用OLD临时表
3.创建触发器
CREATE TRIGGER 触发器名称 触发时机(BEFORE|AFTER) 事件(INSERT|UPDATE|DELETE)
ON 表名称 FOR EACH ROW
BEGIN
语句1;
语句2;
语句3;
END
说明:
触发时机:指在更新、删除、插入之前BEFORE或之后AFTER
3.1 只有一行代码的触发器的例子:
CREATE TRIGGER tr1 AFTER INSERT ON ordertime FOR EACH ROW
insert into ordertime(cid,ordertime) VALUES(NEW.cid,0);
3.2 注意:在同一张表上创建拥有相同触发时机、事件的触发器,是不允许的
mysql> CREATE TRIGGER tr2 AFTER INSERT ON ordertime FOR EACH ROW
-> INSERT INTO `order`(oid,cid,pid,onum) VALUES(5,NEW.cid,2,22);
ERROR 1235 (42000): This version of MySQL doesn't yet support 'multiple triggers with the same action time and event for one table'
说明:如果只有一项相同,是可以创建成功的。
在mysql命令行工具中,\c的意义:取消之前的输入,重新开始输入。
3.3有多行代码的触发器的例子:
DELIMITER //
CREATE TRIGGER t2 BEFORE INSERT ON custom FOR EACH ROW
BEGIN
INSERT INTO `order`(oid,cid,pid,onum) VALUES(5,NEW.cid,1,0);
INSERT INTO `order`(oid,cid,pid,onum) VALUES(6,NEW.cid,2,0);
INSERT INTO `order`(oid,cid,pid,onum) VALUES(7,NEW.cid,3,0);
END
//
3.4 删除操作的触发器
CREATE TRIGGER tr3 AFTER DELETE ON custom FOR EACH ROW
DELETE FROM ordertime WHERE cid=OLD.cid;
4.查看触发器
SHOW TRIGGERS \G
SELECT * FROM information_schema.triggers \G
4.1 SHOW TRIGGERS \G
mysql> SHOW TRIGGERS \G
*************************** 1. row ***************************
Trigger: t2 (触发器名称)
Event: INSERT (触发事件)
Table: custom (触发事件的表名称)
Statement: BEGIN
INSERT INTO `order`(oid,cid,pid,onum) VALUES(5,NEW.cid,1,0);
INSERT INTO `order`(oid,cid,pid,onum) VALUES(6,NEW.cid,2,0);
INSERT INTO `order`(oid,cid,pid,onum) VALUES(7,NEW.cid,3,0);
END
Timing: BEFORE (触发时机)
Created: NULL
sql_mode: NO_ENGINE_SUBSTITUTION
Definer: root@localhost (定义者)
character_set_client: gbk
collation_connection: gbk_chinese_ci
Database Collation: utf8_bin
5. 触发器的调用
触发器是在某事件发生后,自动被调用。
5.1 例子1创建触发器,要求每次录入一个客户的信息(custom),就向订货次数表(ordertime)中插入一条数据,并设置其订货次数(ordertime)为0;
(1)创建触发器
CREATE TRIGGER t1 AFTER INSERT ON custom FOR EACH ROW
INSERT ordertime(cid,ordertime) VALUES(NEW.cid,0);
(2)验证触发器是否实现功能:
mysql> INSERT custom VALUES(110006,'沈阳市粮达饲料有限公司','张海阔');
Query OK, 1 row affected (0.05 sec)
mysql> SELECT * FROM ordertime WHERE cid=110006;
+--------+-----------------+
| cid | ordertime |
+--------+-----------------+
| 110006 | 0 |
+--------+-----------------+
1 row in set (0.00 sec)
5.2 例子2 创建触发器,要求每次插入订单信息(order)时,自动把订货次数(ordertime)加1。
CREATE TRIGGER t2 AFTER INSERT ON `order` FOR EACH ROW
UPDATE ordertime SET ordertime=(ordertime+1) WHERE cid=NEW.cid;
验证触发器功能:
(1) 订货次数表 客户110001 的订货次数现在是2
(2)向订单表插入一条110001的订单信息记录
mysql> INSERT `order` VALUES(5,110001,2,22);
Query OK, 1 row affected (0.06 sec)
(3)查看订货次数表,客户110001的订货次数自动加1,变成3
mysql> SELECT * FROM ordertime WHERE cid=110001;
+--------+--------------------+
| cid | ordertime |
+--------+--------------------+
| 110001 | 3 |
+--------+--------------------+
1 row in set (0.00 sec)
6.删除触发器
DROP TRIGGER 触发器名称
MYSQL触发器学习笔记的更多相关文章
- 基于【 MySql 】二 || mysql详细学习笔记
mysql重点学习笔记 /* Windows服务 */ -- 启动MySQL net start mysql -- 创建Windows服务 sc create mysql binPath= mysql ...
- MySQL数据库学习笔记(十二)----开源工具DbUtils的使用(数据库的增删改查)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- MySQL数据库学习笔记(十)----JDBC事务处理、封装JDBC工具类
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- MySQL数据库学习笔记(九)----JDBC的ResultSet接口(查询操作)、PreparedStatement接口重构增删改查(含SQL注入的解释)
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- Mysql数据库学习笔记之数据库索引(index)
什么是索引: SQL索引有两种,聚集索引和非聚集索引,索引主要目的是提高了SQL Server系统的性能,加快数据的查询速度与减少系统的响应时间. 聚集索引:该索引中键值的逻辑顺序决定了表中相应行的物 ...
- 触发器学习笔记(:new,:old用法)
触发器学习笔记(:new,:old用法) 触发器是数据库发生某个操作时自动运行的一类的程序 用于保持数据的完整性或记录数据库操作信息方面 触发器不能够被直接调用,只能够 ...
- MYSQL数据库学习笔记1
MYSQL数据库学习笔记1 数据库概念 关系数据库 常见数据库软件 SQL SQL的概念 SQL语言分类 数据库操作 创建数据库 查看数据库的定义 删除数据库 修改数据库 创建表 数据类型 约束 ...
- Mysql事务学习笔记
Mysql事务学习笔记 1.事务概述 事务是数据库的执行单元,它包含了一条或多条sql语句,进行的操作是要么全部执行,要么全部都不执行. 2.事务执行命令 语法格式: start transactio ...
- MYSQL进阶学习笔记七:MySQL触发器的创建,应用及管理!(视频序号:进阶_16,17)
知识点八:MySQL触发器的应用(16,17) 触发器的定义: 什么是触发器: 触发器是一种特殊的存储过程,它在插入,删除或修改特定表中的数据是触发执行,他比数据库本身标准的功能有更精细和更复杂的数据 ...
随机推荐
- vipw和vigr命令
Modifying the Configuration Files To add user accounts, it suffices that one line is added to /etc/p ...
- 关于.net类型转换判断问题
做项目时,发现这个问题,由于数据库中的字段可能为null,如果在.net程序直接转换时,比如 ltTime.Text =DateTime.Parse(dt.Rows[0]["m_Time&q ...
- (四)Angularjs - 小实例(2)
自定义指令编写时钟 模板 <!-- 模板文件 --><html> <!-- 内置的ng-app指令通知编译器启动AngularJS框架--> <body ng ...
- Eclipse搭建struts2环境
搭建struts2环境 大的方面分为三步: 1. 加入jar包 2. 在web.xml中配置struts2 3. 添加struts2的配置文件struts.xml 下面是详细步骤: 1. 新建一个Dy ...
- 你好,C++(22) 排排坐,吃果果——4.3.3 for循环:某个范围内…每个都…
4.3.3 for循环:某个范围内…每个都… 既然while语句和do…while…语句都已经可以满足我们表达循环现象的需要,那为什么C++还要专门提供for语句来表达循环现象呢?在现实世界中,常常 ...
- ebay如何确定同一电脑登陆了多个账号,以及同一账号登陆过多台电脑
转自hilton 的BLOG http://jimqu.blog.51cto.com/105370/654691 一切要从ebay的买家保护说起 ebay作为一个电子商务平台,之所以可以汇聚如此众多的 ...
- HTML5 Canvas 中的颜色、样式和阴影的属性和方法
颜色.样式和阴影的属性与方法 fillStyle 设置或返回用于填充绘画的颜色.渐变或模式 strokeStyle 设置或返回用于笔触的颜色.渐变或模式 ...
- box flex 弹性盒模型(转载)
css3引入了新的盒模型——弹性盒模型,该模型决定一个盒子在其他盒子中的分布方式以及如何处理可用的空间.这与XUL(火狐使用的用户交互语言)相似,其它语言也使用相同的盒模型,如XAML .GladeX ...
- sunJCE or ibmJce,was服务器下使用des的注意点
最近开发了一个应用,在tomcat下一切ok,到was上有报错. 打开debug日志,没有异常?? 继续调查发现是我们的程序引用了一个sun很久以前的jar.这个jar需要单独打开message日志 ...
- SQLServer 2008 删除、压缩日志
SQL Server 2008删除或压缩数据库日志的方法 由于数据库日志增长被设置为“无限制”,所以时间一长日志文件必然会很大,一个400G的数据库居然有600G的LOG文件,严重占用了磁盘空间.由于 ...