`
qzriso
  • 浏览: 244291 次
  • 性别: Icon_minigender_1
  • 来自: ph
社区版块
存档分类
最新评论

MySQL 5.0 触发器

阅读更多

Introduction

本书是为需要了解5.0版本新特性的MySQL老用户而写的。简单的来说介绍了"存储过程、触发器、视图、信息架构视图",这是介绍MySQL 5.0新特性丛书的第一集。希望这本书能像内行专家那样与您进行对话,用简单的问题、例子让你学到需要的知识。为了达到这样的目的,我会从每一个细节开始慢的为大家建立概念,最后会给大家展示较大的实用例,在学习之前也许大家会认为这个用例很难,但是只要跟着课程去学,相信很快就能掌握。


Conventions and Styles约定和编程风格

每次我想要演示实际代码时,我会对mysql客户端的屏幕就出现的代码进行调整,将字体改成Courier,使他们看起来与普通文本不一样(让大家区别程序代码和正文)。在这里举个例子:


mysql> DROP FUNCTION f;
Query OK, 0 rows affected (0.00 sec)


如果实例比较大,则需要在某些行和段落间加注释,同时我会用将"<--"符号放在页面的右边以表示强调。例如:


mysql> CREATE PROCEDURE p ()
-> BEGIN
-> /* This procedure does nothing */ <--
-> END;//
Query OK, 0 rows affected (0.00 sec)


有时候我会将例子中的"mysql>"和"->"这些系统显示去掉,你可以直接将代码复制到mysql客户端程序中(如果你现在所读的不是电子版的,可以在mysql.com网站下载相关脚本)


所以的例子都已经在Suse 9.2 Linux、Mysql 5.0.3公共版上测试通过。在您阅读本书的时候,Mysql已经有更高的版本,同时能支持更多OS了,包括Windows,Sparc,HP-UX。因此这里的
例子将能正常的运行在您的电脑上。但如果运行仍然出现故障,可以咨询你认识的资深Mysql用户,这样就能得到比较好的支持和帮助。转载请注明翻译者陈朋奕及转自:www.phpv.net


Why Triggers 为什么要用触发器


我们在MySQL 5.0中包含对触发器的支持是由于以下原因:


MySQL早期版本的用户长期有需要触发器的要求。
我们曾经许诺支持所有ANSI标准的特性。
您可以使用它来检查或预防坏的数据进入数据库。
您可以改变或者取消INSERT, UPDATE以及DELETE语句。
您可以在一个会话中监视数据改变的动作。

在这里我假定大家都读过"MySQL新特性"丛书的第一集--"MySQL存储过程",那么大家都应该知道MySQL至此存储过程和函数,那是很重要的知识,因为在触发器中你可以使用在函数中使用的语句。特别举个例子:


复合语句(BEGIN / END)是合法的.转载请注明翻译者陈朋奕及转自:www.phpv.net

流控制(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)缺陷.所以我在这里给大家警告,就像我在存储过程书中所说那样.不要在含有重要数据的数据库中使用这个触发器,如果需要的话在一些以测试为目的的数据库上使用,同时在你对表创建触发器时确认这些数据库是默认的。

 

Syntax 语法

1. Syntax: Name 语法:命名规则 转载请注明翻译者陈朋奕及转自:www.phpv.net


CREATE TRIGGER <触发器名称>               <--
{ BEFORE | AFTER }
{ INSERT | UPDATE | DELETE }
ON <表名称>
FOR EACH ROW
<触发器SQL语句>


触发器必须有名字,最多64个字符,可能后面会附有分隔符.它和MySQL中其他对象的命名方式基本相象.


这里我有个习惯:就是用表的名字+'_'+触发器类型的缩写.因此如果是表t26,触发器是在事件UPDATE(参考下面的点(2)和(3))之前(BEFORE)的,那么它的名字就是t26_bu。

 

2. Syntax: Time 语法:触发时间


CREATE TRIGGER <触发器名称>
{ BEFORE | AFTER } <--
{ INSERT | UPDATE | DELETE }
ON <表名称>
FOR EACH ROW
<触发的SQL语句>


触发器有执行的时间设置:可以设置为事件发生前或后。

 

3. Syntax: Event语法:事件


CREATE TRIGGER <触发器名称>
{ BEFORE | AFTER }
{ INSERT | UPDATE | DELETE } <--
ON <表名称>
FOR EACH ROW
<触发的SQL语句>


同样也能设定触发的事件:它们可以在执行insert、update或delete的过程中触发。

 

4. Syntax: Table 语法:表


CREATE TRIGGER <触发器名称>
{ BEFORE | AFTER }
{ INSERT | UPDATE | DELETE }
ON <表名称>                    <--
FOR EACH ROW
<触发的SQL语句>


触发器是属于某一个表的:当在这个表上执行插入、更新或删除操作的时候就导致触发器的激活.
我们不能给同一张表的同一个事件安排两个触发器。

 

5. Syntax: Granularity 语法:( :( 步长)触发间隔

 

CREATE TRIGGER <触发器名称>
{ BEFORE | AFTER }
{ INSERT | UPDATE | DELETE }
ON <表名称>
FOR EACH ROW                 <--
<触发的SQL语句>

 

触发器的执行间隔:FOR EACH ROW子句通知触发器每隔一行执行一次动作,而不是对整个表执行一次。

 


6. Syntax: Statement 语法:语句


CREATE TRIGGER <触发器名称>
{ BEFORE | AFTER }
{ INSERT | UPDATE | DELETE }
ON <表名称>
FOR EACH ROW
<触发的SQL语句>                      <--

 

触发器包含所要触发的SQL语句:这里的语句可以是任何合法的语句,包括复合语句,但是这里的语句受的限制和函数的一样。

 

Privileges权限


你必须拥有相当大的权限才能创建触发器(CREATE TRIGGER)。如果你已经是Root用户,那么就足够了。这跟SQL的标准有所不同,我也希望能尽快改成标准的。


因此在下一个版本的MySQL中,你完全有可能看到有一种叫做CREATE TRIGGER的新权限。然后通过这样的方法赋予:


GRANT CREATE TRIGGER ON <表名称> TO <用户或用户列表>;


也可以通过这样收回权限:


REVOKE CREATE TRIGGER ON <表名称> FROM <用户或用户列表>;


Referring to OLD and NEW columns 关于旧的和新创建的列的标识


在触发器的SQL语句中,你可以关联表中的任意列。但你不能仅使用列的名称去标识,那会使系统混淆,因为那里可能会有列的新名(这可能正是你要修改的,你的动作可能正是要修改列名),还有列的旧名存在。因此你必须用这样的语法来标识:

"NEW . column_name"或者"OLD . column_name".这样在技术上处理(NEW | OLD . column_name)新和旧的列名属于创建了过渡变量("transition variables")。


对于INSERT语句,只有NEW是合法的;对于DELETE语句,只有OLD才合法;而UPDATE语句可以在和NEW以及OLD同时使用。下面是一个UPDATE中同时使用NEW和OLD的例子。


CREATE TRIGGER t21_au
BEFORE UPDATE ON t22
FOR EACH ROW
BEGIN
SET @old = OLD . s1;
SET @new = NEW.s1;
END;//


现在如果t21表中的s1列的值是55,那么执行了"UPDATE t21 SET s1 = s1 + 1"之后@old的值会变成55,而@new的值将会变成56。

 


Example of CREATE and INSERT CREATE和INSERT的例子


CREATE table with trigger创建有触发器的表


这里所有的例程中我都假定大家的分隔符已经设置成//(DELIMITER //)。


CREATE TABLE t22 (s1 INTEGER)//


CREATE TRIGGER t22_bi
BEFORE INSERT ON t22
FOR EACH ROW
BEGIN
SET @x = 'Trigger was activated!';
SET NEW.s1 = 55;
END;//


在最开始我创建了一个名字为t22的表,然后在表t22上创建了一个触发器t22_bi,当我们要向表中的行插入时,触发器就会被激活,执行将s1列的值改为55的动作。

 

INSERT on table w ith a trigger使用触发器执行插入动作


mysql> INSERT INTO t22 VALUES (1)//


让我们看如果向表t2中插入一行数据触发器对应的表会怎么样?


这里的插入的动作是很常见的,我们不需要触发器的权限来执行它。甚至不需要知道是否有触发器关联。


mysql> SELECT @x, t22.* FROM t22//
+------------------------+------+
| @x              | s1   |
+------------------------+------+
| Trigger was activated! | 55 |
+------------------------+------+
1 row in set (0.00 sec)


大家可以看到INSERT动作之后的结果,和我们预期的一样,x标记被改动了,同时这里插入的数据不是我们开始输入的插入数据,而是触发器自己的数据。

Example of a "check" constraint
"check"完整性约束例子


What's a "check" constraint 什么是"check"约束


在标准的SQL语言中,我们可以在(CREATE TABLE)创建表的过程中使用"CHECK (condition)",
例如:

CREATE TABLE t25
(s1 INT, s2 CHAR(5), PRIMARY KEY (s1),
CHECK (LEFT(s2,1)='A'))
ENGINE=INNODB;


这里CHECK的意思是"当s2列的最左边的字符不是'A'时,insert和update语句都会非法",MySQL的视图不支持CHECK,我个人是很希望它能支持的。但如果你很需要在表中使用这样的功能,我建议大家使用触发器来实现。


CREATE TABLE t25
(s1 INT, s2 CHAR(5),
PRIMARY KEY (s1))
ENGINE=INNODB//


CREATE TRIGGER t25_bi
BEFORE INSERT ON t25
FOR EACH ROW
IF LEFT(NEW.s2,1)<>'A' THEN SET NEW.s1=0; END IF;//


CREATE TRIGGER t25_bu
BEFORE UPDATE ON t25
FOR EACH ROW
IF LEFT(NEW.s2,1)<>'A' THEN SET NEW.s1=0; END IF;//


我只需要使用BEFORE INSERT和BEFORE UPDATE语句就行了,删除了触发器不会对表有影响,同时AFTER的触发器也不能修改NEW的过程变量(transition variables)。为了激活触发器,我执行了向表中的行插入s1=0的数据,之后只要执行符合LEFT(s2,1) <> 'A'条件的动作都会失败:转载请注明翻译者陈朋奕及转自:www.phpv.net


INSERT INTO t25 VALUES (0,'a') /* priming the pump */ //
INSERT INTO t25 VALUES (5,'b') /* gets error '23000' */ //


Don't Believe The Old MySQL Manual
该抛弃旧的MySQL的手册了

我在这里警告大家不要相信过去的MySQL手册中所说的了。我们已经去掉了关于触发器的错误的语句,但是仍旧有很多旧版本的手册在网上,举个例子,这是一个德国的Url上的:
http://dev.mysql.com/doc/mysql/de/ANSI_diff_Triggers.html .


这个手册上说触发器就是存储过程,忘掉吧,你也已经看见了,触发器就是触发器,而存储过程还是存储过程。


手册上还说触发器可以从其他表上来删除,或者是当你删除一个事务的时候激发,无论他说的是什么意思,忘掉吧,MySQL不会去实现这些的。 转载请注明翻译者陈朋奕及转自:www.phpv.net


最后关于说使用触发器会对查询速度产生影响的说法也是错的,触发器不会对查询产生任何影响。

 

Bugs
(不好的东西就不翻译了)
On December 14 2004, I did an "Advanced Search" in http://bugs.mysql.com/ for 'trigger' or
'triggers', I found that there were 17 active bugs as of that date. Of course they might disappear
before you read this, but just in case they haven't, I'll mention the important ones. If they're still
there, you'll have to work around them when you're trying triggers.


Bug#5859    DROP TABLE does not drop triggers.
(删除表的时候没有自动删除触发器)
When you drop a table, dropping the table's triggers should be automatic.


Bug#5892    Triggers have the wrong namespace.
(触发器的命名空间有错,你必须在前面加上表的名字才能删除触发器,下面是例子)
You have to say "DROP TRIGGER <table name> . <trigger name>".
The correct way is "DROP TRIGGER <trigger name>".


Bug#5894    Triggers with altered tables cause corrupt databases.
(触发器对表的改变可能会造成数据库数据被破坏)
Do not alter a table that has a trigger on it, until you know this is fixed.

分享到:
评论

相关推荐

    MySQL 5.0 触发器.rar

    在学习和使用MySQL 5.0触发器的过程中,你可以参考提供的书籍教程《MySQL 5.0 触发器》。这本书可能涵盖了触发器的基础概念、创建和管理触发器的方法、示例应用以及最佳实践。同时,文件`下载说明.txt`可能包含获取...

    MySQL 5.0触发器参考教程第1/4页

    MySQL 5.0触发器是数据库管理系统中一种强大的工具,用于自动执行特定操作,当数据库中的数据发生变化(如INSERT、UPDATE或DELETE)时。在本教程中,我们将深入探讨触发器的基本概念、用途以及如何在MySQL 5.0中创建...

    mysql安装包mysql5.0

    MySQL 5.0是MySQL数据库管理系统的一个早期版本,它在当时提供了可靠且高效的数据存储解决方案。MySQL是一款开源的关系型数据库管理系统(RDBMS),由瑞典的MySQL AB公司开发,后来被Oracle公司收购。它的设计目标是...

    Mysql 5.0 32位

    1. **关系型数据库模型**:MySQL 5.0基于SQL标准,支持创建和管理表、视图、索引、触发器和存储过程等数据库对象,实现了关系型数据库的主要特性。 2. **安装与配置**:在32位操作系统上安装mysql-5.0.67-win32文件...

    mysql 5.0 解压版

    MySQL 5.0 版本引入了存储过程、触发器、视图等高级特性,提高了数据库的灵活性和性能。 1. **安装与解压**:MySQL 5.0 解压版意味着它不需要经过传统的安装过程,只需要将压缩包解压到指定目录。首先,找到下载的...

    mysql5.0.75tar.gz

    5. **SQL 改进**:MySQL 5.0 提供了更完整的 SQL 支持,包括窗口函数、存储过程、触发器、视图、用户定义函数(UDF),以及改进的查询优化器。 6. **安全性**:此版本加强了安全性,包括更强大的认证机制(如 SSL ...

    MySql5.0下载

    2. **触发器与存储过程**:MySQL5.0开始支持触发器和存储过程,这使得数据库能够执行更复杂的业务逻辑,无需在应用程序层面处理,简化了数据库的管理和维护。 3. **分区功能**:在MySQL5.0中,数据库表可以被分区,...

    mysql5.0 安装板

    - MySQL 5.0 引入了触发器和存储过程,使得开发者可以在数据库级别实现复杂业务逻辑,提高了应用程序的效率。 8. **XML支持**: - MySQL 5.0 开始支持XML格式的数据,便于数据交换和集成其他系统。 9. **网络...

    MySql5.0 免安装版

    MySQL5.0免安装版是一款无需复杂安装过程的数据库管理系统,它允许用户快速启动并使用MySQL服务,尤其适合开发者在测试环境或者临时项目中快速部署。这个版本的MySQL以其便捷性和高效性受到许多用户的青睐。 MySQL...

    mysql5.0安装包+安装步骤文档

    3. **触发器和存储过程**:MySQL 5.0引入了触发器和存储过程,允许用户在数据库级别定义复杂的业务逻辑,提高了代码复用性和数据库管理效率。 4. **分区功能**:对于大型数据表,MySQL 5.0提供了分区功能,可以将一...

    MySQL5.0工具

    首先,MySQL5.0引入了增强的SQL支持,包括对存储过程、触发器、视图和事务处理的支持。这些特性使得MySQL5.0能够处理更复杂的业务逻辑,增强了其在企业级应用中的能力。存储过程允许开发者将一系列SQL语句打包成一个...

    mysql5.0中文使用手册

    这份“mysql5.0中文使用手册”为那些对英文文档不熟悉的用户提供了一条便捷的学习路径,它涵盖了MySQL 5.0的所有主要功能和操作。 手册可能包括以下内容: 1. **安装与配置**:介绍如何在不同操作系统上安装MySQL ...

    MySql5.0安装程序

    MySQL5.0是MySQL数据库管理系统的一个重要版本,它在数据库领域具有广泛的使用,尤其适合中小型企业及个人开发者。本文将详细介绍MySQL5.0的安装过程及其相关知识点。 首先,MySQL5.0.22是该版本的一个具体发行版,...

    mysql 5.0 for windows

    MySQL 5.0是MySQL数据库管理系统的一个重要版本,专为Windows操作系统设计,提供高效、可靠的数据库服务。在本文中,我们将深入探讨MySQL 5.0的关键特性、安装过程以及与数据库相关的基础知识。 **1. MySQL简介** ...

    MySql5.0工具

    MySQL 5.0是MySQL数据库管理系统的一个重要版本,它在2005年发布,带来了许多新特性和改进。MySQL是一种流行的开源关系型数据库管理系统(RDBMS),因其高效、可靠且易于使用而广受开发者喜爱。以下是关于MySQL 5.0...

    mysqltrigger触发器.pdf

    根据提供的文件信息,本文将重点解析 MySQL 5.0 版本中新引入的触发器功能,并结合描述中的信息深入探讨其特性和应用场景。 ### MySQL 5.0 触发器 #### 引言 MySQL 5.0 版本是一个重要的里程碑,因为它引入了许多...

    mysql 5.0 下载(jsp程序员必备)

    MySQL 5.0引入了许多新特性和性能优化,如增强的存储引擎(包括InnoDB和MyISAM)、改进的查询优化器、支持存储过程、触发器和视图等。这些特性极大地提高了数据库管理的灵活性和功能性,为开发人员提供了更多处理...

    mysql5.0数据库

    - MySQL 5.0引入了触发器和存储过程,这允许在数据库级别定义自动执行的操作,提升了数据库的逻辑处理能力。 5. **分区** - 数据库分区是MySQL 5.0的一个新特性,它将大表分成多个物理部分,提高查询速度和管理...

    mysql5.0+详细教程

    这个“mysql5.0+详细教程”涵盖了从安装到实际操作的全过程,对于初学者和进阶用户都是极好的学习资源。 首先,我们需要了解MySQL 5.0的安装过程。`Setup.exe`文件通常是安装程序,这意味着教程可能包含了Windows...

Global site tag (gtag.js) - Google Analytics