MySQL5触发器教程

2008-02-23 07:43:04来源:互联网 阅读 ()

新老客户大回馈,云服务器低至5折

约定和编程风格

每次我想要演示实际代码时,我会对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用户,这样就能得到比较好的支持和帮助。

为什么要用触发器

我们在MySQL 5.0中包含对触发器的支持是由于以下原因:
MySQL早期版本的用户长期有需要触发器的需要。

我们曾许诺支持任何ANSI标准的特性。

您能够使用他来检查或预防坏的数据进入数据库。

您能够改变或取消INSERT, UPDATE连同DELETE语句。

您能够在一个会话中监控数据改变的动作。
在这里我假定大家都读过"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)缺陷.所以我在这里给大家警告,就像我在存储过程书中所说那样.不要在含有重要数据的数据库中使用这个触发器,假如需要的话在一些以测试为目的的数据库上使用,同时在您对表创建触发器时确认这些数据库是默认的。

语法
1. 语法:命名规则



CREATE TRIGGER <触发器名称> <--

{ BEFORE | AFTER }

{ INSERT | UPDATE | DELETE }

ON <表名称>

FOR EACH ROW

<触发器SQL语句>

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

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



CREATE TRIGGER <触发器名称>

{ BEFORE | AFTER } <--

{ INSERT | UPDATE | DELETE }

ON <表名称>

FOR EACH ROW

<触发的SQL语句>



触发器有执行的时间配置:能够配置为事件发生前或后。



3. 语法:事件



CREATE TRIGGER <触发器名称>

{ BEFORE | AFTER }

{ INSERT | UPDATE | DELETE } <--

ON <表名称>

FOR EACH ROW

<触发的SQL语句>



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

4. 语法:表



CREATE TRIGGER <触发器名称>

{ BEFORE | AFTER }

{ INSERT | UPDATE | DELETE }

ON <表名称> <--

FOR EACH ROW

<触发的SQL语句>



触发器是属于某一个表的:当在这个表上执行插入、

更新或删除操作的时候就导致触发器的激活.

我们不能给同一张表的同一个事件安排两个触发器。



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



CREATE TRIGGER <触发器名称>

{ BEFORE | AFTER }

{ INSERT | UPDATE | DELETE }

ON <表名称>

FOR EACH ROW <--

<触发的SQL语句>



触发器的执行间隔:FOR EACH ROW子句通知触发器

每隔一行执行一次动作,而不是对整个表执行一次。



6. 语法:语句



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 <用户或用户列表>;

关于旧的和新创建的列的标识

在触发器的SQL语句中,您能够关联表中的任意列。但您不能仅使用列的名称去标识,那会使系统混淆,因为那里可能会有列的新名(这可能正是您要修改的,您的动作可能正是要修改列名),更有列的旧名存在。因此您必须用这样的语法来标识: "NEW . column_name"或"OLD . column_name".这样在技术上处理(NEW | OLD . column_name)新和旧的列名属于创建了过渡变量("transition variables")。

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

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇: 在MacOS下的安装MySQL5.0.15

下一篇: PHP5连接mysql5的认证协议问题